在C ++中一次取大整数输入

时间:2010-12-03 05:01:22

标签: c++ integer integer-overflow

我希望一次获取一个1000位整数输入,&想要分别添加数字。是否有任何输入方法来获取如此大的输入?

6 个答案:

答案 0 :(得分:3)

您需要将其输入为字符串。拆分它们,并将每个字符转换为整数。添加它们,你就完成了。

示例,此处的数字(随机生成):

9624526619162264306083309360203157186784123851390498919674886891002552146753945797326679482200717699585297042606470048297021049209667042255911984240697992738371633115195140494325737382583412562136836759072897211537655046343769659111215754043609344618490646811291135643554115350431099553593485744944746093896695837300975718819726339233383800764568364950577294931831936979504756278187812548901366714205562309364234394802723329400976924082450161974562063268243689930750925213262044910428021004262080895556879515597779404780565380480750286553508081070834339176079062215815331059349488936312244526697733596052063044560959189161656978673936732284706841120711543620038686227462170335634371808995466024671420024705248851244350701111587608201303840696489479021196275228499780922745352396928865910631672384263395712487735712098161853665189905194589355110620257494673972892816413534347360049692019184831019218764766067298983043791063184786671132332077197148683743991683245617836086353821268720434176862469084808

这是C ++程序:

int strint(std::string &str) {
    int i;
    std::stringstream intstr(str);
    intstr >> i;
    return i;
}

int main () {
    std::string strdigit, schar;
    int sum = 0;
    std::cout << "Enter Digits: ";
    std::cin >> strdigit;
    std::stringstream ss;
    for (int i = 0; i < strdigit.length(); i++) {
        ss.clear();
        ss << strdigit[i];
        ss >> schar;
        sum += strint(schar);
    }
    std::cout << sum;
}

总和为:4479

答案 1 :(得分:2)

只需将数字读入字符串并使用std :: accumulate即可。例如:

std::string str("1234567890"); // your number here

int result = std::accumulate(str.begin(), str.end(), 0, [](int val, char ch)
{
    return val + (ch - '0');
});

std::cout << result << '\n'; // display the answer

答案 2 :(得分:0)

您需要一个库来为此提供支持。

答案 3 :(得分:0)

将数字读入字符串并使用多精度数学库(例如GMP)进行添加。该库应具有在数字字符串和库的内部数字表示之间进行转换的功能。

(实际上,看起来GMP可以直接从istream读取数字,因此您甚至可能不需要字符串。)

答案 4 :(得分:0)

我对这个问题有点不清楚。如果你是分别添加数字,那么我会认为你把它当作字符串而不是整数(至少,直到你开始加起来的数字)。

你能说明1000位整数需要如何存储在内存中吗?

答案 5 :(得分:0)

正如马龙所说,为什么不简单地使用好的'ol for loop和string?

int main() {
        string str = "3985792792679283635";
        int len = str.length();
        int sum = 0;
        for(int i = 0; i < len; i++) {
                sum += str[i] - '0';
        }
        cout << sum << endl;

}