师弟突然惊慌的过来找我,说道:“师兄,加法器出bug了?”
我问:“咋啦?啥bug?”
师弟囧囧的说道:“两个正数相加变成了负数了。还是我喜欢的女生发现的,丢人了。”
我问:“你喜欢的女生,我们系的吗?”
师弟不无沮丧的说:“关键人家还是文科生。”
我说:“没关系,我们来分析看看问题。”
其实我大致猜到了原因。
问题分析
女生输入的数据为 a=2147483647, b=1
执行后的结果为: -2147483648
为什么会出现这样的结果呢?我们来看一下代码。
#include <stdio.h>
int add(int a, int b) { //加法函数
int sum = a + b; //两个数相加
return sum; //返回两个数的和
}
int main()
{
int a, b, sum;
scanf("%d %d", &a, &b); //标准输入函数,会将读入的值赋给a和b
sum = add(a, b); //调用加法函数,将返回值赋值给sum变量
printf("sum=%d\n", sum); //标准输出函数,终端打印a+b的和
}
因为a 和 b都是int型变量,在操作系统中,占位32bit,也即取值范围在 -231——231-1 (-2147483648——2147483647),a+b=2147483648 超出了int型取值范围,溢出了,变成了0x80000000,也即-2147483648。
如果想得到正确的结果应该怎么改变呢?可以修改sum的类型为long long int型,在操作系统中占64bit。
修改后的代码如下:
#include <stdio.h>
long long int add(int a, int b) { //加法函数
long long int sum = (long long int)a + (long long int)b; //两个数相加
return sum; //返回两个数的和
}
int main()
{
int a, b;
long long int sum;
scanf("%d %d", &a, &b); //标准输入函数,会将读入的值赋给a和b
sum = add(a, b); //调用加法函数,将返回值赋值给sum变量
printf("sum=%lld\n", sum); //标准输出函数,终端打印a+b的和
}
后记
我说:“不是我说你,你说你给你喜欢的女生,发什么加法器,直接发一颗爱心不好么?”
师弟害羞的笑道:“这不是还没学会么。”
我说:“这还不简单。”
#include <stdio.h>
#include <string.h>
int main()
{
printf(" *** ***\n");
printf(" ** ** ** **\n");
printf(" ** **** **\n");
printf("** ^_^ ^_^ **\n");
printf("** **\n");
printf(" ** **\n");
printf(" ** **\n");
printf(" ** **\n");
printf(" ** **\n");
printf(" ** **\n");
printf(" ****\n");
return 0;
}
当然,还可以做更多有特色技巧的,含有技术的小心心,做一个温暖的技术人。