C++不能正确输出1000000000000
很奇怪,通过变量相加得到的大数输出不正确,但直接声明大数却可以正确输出。
#include <string>
#include <iostream>
#include <algorithm>
#include <vector>
int main(void)
{
std::string s;
std::cin >> s;
long n;
std::cin >> n;
int length = s.length();
int a_count_length = std::count(s.begin(), s.end(), 'a');
long count = a_count_length * int(n / length) + std::count(s.begin(), s.begin()+(n%length), 'a'); // 这里是大数 + 0
std::cout << count << std::endl;
long q = 1000000000000; // 直接声明大数
std::cout << q << std::endl;
return 0;
}
程序输入和输出结果是这样的:
a // 输入
1000000000000 // 输入
-727379968 //输出
1000000000000 //输出
请教为什么同样是大数的输出,但是结果却不同?
如果你对这篇内容有疑问,欢迎到本站社区发帖提问 参与讨论,获取更多帮助,或者扫码二维码加入 Web 技术交流群。
绑定邮箱获取回复消息
由于您还没有绑定你的真实邮箱,如果其他用户或者作者回复了您的评论,将不能在第一时间通知您!
发布评论
评论(2)
a_count_length * int(n / length) + std::count(s.begin(), s.begin()+(n%length), 'a');
这里所有操作数都是 int 的,所以结果是 int 的,溢出,得到-727379968
。然后再将这个值转为 long 赋值给count
,所以count
是-727379968
。适当的把操作数为变
long
应该可以解决你的问题另外还要看你的
a_count_length
是不是够大,是不是需要 long 来保存int+int还是等于int,你要从一开始就是long,在结果那里转类型是没有用的。