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

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

阅读 3.4k
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,在结果那里转类型是没有用的。

撰写回答
你尚未登录,登录后可以
  • 和开发者交流问题的细节
  • 关注并接收问题和回答的更新提醒
  • 参与内容的编辑和改进,让解决方法与时俱进
推荐问题