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

查看:99
本文介绍了变量 - 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    //输出

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

解决方案

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

这篇关于变量 - C++不能正确输出1000000000000的文章就介绍到这了,希望我们推荐的答案对大家有所帮助,也希望大家多多支持IT屋!

查看全文
登录 关闭
扫码关注1秒登录
发送“验证码”获取 | 15天全站免登陆