问题描述
题目是输入两个正整数,输出他们的和。输入的数在1(含)到10^6(含)之间。用scanf和printf就所有的测试用例都能通过,用cin和cout的话就总是有两个测试用例是wrong answer?但是实在看不出有什么问题。。用scanf的代码:
double a, b; scanf('%lf %lf',&a,&b); printf('%.0lf', a + b);
用cin,cout的代码:
double x, y; cin >> x >> y; cout << x + y;
请问是哪儿可能导致这两种写法有不同的结果?
问题解答
回答1:是因为超过一百万的结果会被cout输出成科学计数法形式,所以有的case无法通过。用double而不是int,虽然确实浪费内存,但是在只做正整数的加法的时候并不会因为精度而出错。
回答2:两个数都是正整数的话,输出的数也肯定是整数。题意已经交代清楚的话,没必要用double
回答3:你都换成整数就行了,不懂为什么要用浮点数,浮点数跟精度有关,容易出错。
回答4:是不是有些大的数字浮点加以后会出现舍入误差而使得结果为xxx.00000001之类的既然说明用整数也给了范围 那用普通的int类型即可 在现在所有主流平台上int至少都32位了