变量 - C++不能正确输出1000000000000

浏览:44日期:2023-04-15

问题描述

很奇怪,通过变量相加得到的大数输出不正确,但直接声明大数却可以正确输出。

#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 //输出

请教为什么同样是大数的输出,但是结果却不同?

问题解答

回答1:

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 来保存

回答2:

int+int还是等于int,你要从一开始就是long,在结果那里转类型是没有用的。

相关文章: