【c】对bug的排查

也许你得对照阅读之前一篇博文的内容

        aver /= i;
    printf("%d\n",aver);

如前篇所示,aver是粘土体积的平均数,我在求平均数的时候加入了这么一行代码,来显示aver的值

又在main函数里加入了这么一行显示i的值,可能是i出错了

printf("%d\n",i); 
find(i);
scanf( "%d", &i ); 

接着又在find函数里的第一个for循环里加入这么一行,再次显示aver的值

        aver += kid[n].v;
        printf("%d\n",aver);

 

回顾样例输入

样例输入

3
10 10 2 Jill
5 3 10 Will
5 5 10 Bill
4
2 4 10 Cam
4 3 7 Sam
8 11 1 Graham
6 2 7 Pam
-1

输出是这样的
200
350
600
Bill took clay from Will.
4
280
364
452
536
Graham took clay from Pam.
好好的cam变成了pam,处理第二组数据时aver变成了280
再回头看看aver的赋值语句和声明语句
      int aver;  
aver += kid[n].v;

 

    其中aver += kid[n].v;等价于aver = aver + kid[n].v;
卧槽!
吐血三升冲冠而起啊……
虽然已经明白是什么情况了,但是把输入数据改成

样例输入

3
10 10 6 Jill
15 3 10 Will
15 5 10 Bill
4
2 4 10 Cam
4 3 7 Sam
8 11 1 Graham
6 2 7 Pam
-1
输出变成了
3
600
1050
1800
Bill took clay from Will.
4
680
764
852
936
Graham took clay from Pam.
aver并没有在声明的时候赋值,而当main第二次调用find函数时,系统分配给aver变量的内存地址仍旧是上一个aver变量的地址,上一个aver变量的值是200,因而这个aver的值就是200,所以才会输出280 364 452 536
而当上一个aver的值是600,下一个aver就是680 764 852 936了
over
解决整个bug只需要一个初始化
 
 


 



 

 

posted @ 2016-01-17 23:48  1193972689  阅读(122)  评论(0编辑  收藏  举报