watch-监测命令的运行结果

watch 是一个非常实用的命令,基本所有的 Linux 发行版都带有这个小工具,如同名字一样,watch 可以帮你监测一个命令的运行结果,省得你一遍遍的手动运行。

举例来说,Linux 系统有一个基础命令 w,可以显示当前的 uptime、负载还有登录的用户,非常方便,但是如果我想监测这些数据,看看有没有新用户登入,看看某段的时间的负载是不是太大之类的,就得手动一遍遍的运行这个命令,然后查看结果,虽然命令只有一个字母,但是还是很郁闷……

watch 就是干这个用的,直接在 watch 后面接你想运行的命令,watch 就会帮你重复运行,并把每次的结果都更新在屏幕上~

要想监测 w 命令的运行结果,只要 watch w 就可以了:

默认 watch 会以 2s 的间隔重复运行命令,你也可以用 -n 参数指定时间间隔~

还有一个实用的参数是 -d,这样 watch 会帮你高亮显示变化的区域,这样更加一目了然了~

Ctrl c 就可以退出~

你可以拿他来监测你想要的一切命令的结果变化,比如 tail 一个 log 文件,ls 监测某个文件的大小变化,看你的想象力了~

PS:

watch 属于 procps 这个软件包。

Barn Repair

第一章还没通关是一件很尴尬的事

 

这道题本来想用动归解得的,一来比较帅,二来好久没用过了,代码如下:

/*
ID: roselone
LANG: C++
TASK: barn1
*/


//动态规划求解,
//将有牛的牛棚排序后,设置一个函数d[i,j]表示第i个牛修到第j个牛需要使用的木版长度,设f[i,j]表示用前i个木版修到第j头牛所用的最短长度.
//f[i,j]=min{f[i-1,k]+d[k,j]}; (i<=k<=j)
#include<iostream>
#include<fstream>
#include<string>
#include<algorithm>

using namespace std;
int d[201][201];
int f[51][201];
int m,s,c;
int a[51];
ifstream fin("castle.txt");
ofstream fout("barn1.out");
bool cmp(int a,int b)
{
        return (a<b);
}

void init()
{
        fin>>m>>s>>c;
        for (int i=1;i<=c;i++)
                fin>>a[i];
        sort(a+1,a+c+1,cmp);
        for (int i=1;i<=c;i++)
        {       d[i][i]=1;
        f[i][i]=i;}
        for (int i=1;i<=c;i++)
                {f[1][i]=a[i]-a[1]+1; }
        for (int i=1;i<c;i++)
                for (int j=i+1;j<=c;j++)
                        d[i][j]=a[j]-a[i]+1;
}

int main()
{
        init();
        for (int i=2;i<=m;i++)
                for (int j=i;j<=c;j++)
                {  f[i][j]=220;
                        for (int k=i;k<=j;k++)
                        {
                                int temp=f[i-1][k-1]+d[k][j];
                                if (temp<f[i][j]) f[i][j]=temp;
                        }
                }
        if (m>=c) fout<<c<<endl;
        else
        cout<<f[m][c]<<endl;                               
        return 0;
}

 

 

编译没问题,前几个测试数据也顺利通过了,但是第5个竟奇迹般的出现运行时错误,被迫中止,郁闷啊……

调试,再调试……

咦?越界么?

原来是数组a开的太小了,应该用c的最大值,又是题目没看清,改成a[201]后~~AC~!

 

 USER: rose lone [roselon2]
TASK: barn1
LANG: C++

Compiling...
Compile: OK

Executing...
Test 1: TEST OK [0.011 secs, 3044 KB]
Test 2: TEST OK [0.022 secs, 3040 KB]
Test 3: TEST OK [0.011 secs, 3040 KB]
Test 4: TEST OK [0.000 secs, 3044 KB]
Test 5: TEST OK [0.000 secs, 3040 KB]
Test 6: TEST OK [0.022 secs, 3040 KB]
Test 7: TEST OK [0.011 secs, 3040 KB]
Test 8: TEST OK [0.011 secs, 3040 KB]
Test 9: TEST OK [0.000 secs, 3040 KB]
Test 10: TEST OK [0.011 secs, 3040 KB]

All tests OK.

Your program ('barn1') produced all correct answers! This is your
submission #5 for this problem. Congratulations!