系列中最大的产品(项目Euler#8)

时间:2016-05-25 12:23:15

标签: c++

我想解决项目Euler问题#8,我想在我继续解决13位数问题之前先尝试做4位连续数字的最大乘积(我想它会以同样的方式解决?),我尝试了下面的代码,但它给了我一个很大的数字,而不是正确的答案应该是5832,它给了我10370808,我无法弄清楚为什么,有人可以帮助我吗?谢谢。

#include <iostream>
#include <string>
#include <vector>
#include <algorithm>
int main(){
std::vector<int>store(1000);
std::string numbers = "7316717653133062491922511967442657474235534919493496983520312774506326239578318016984801869478851843858615607891129494954595017379583319528532088055111254069874715852386305071569329096329522744304355766896648950445244523161731856403098711121722383113622298934233803081353362766142828064444866452387493035890729629049156044077239071381051585930796086670172427121883998797908792274921901699720888093776657273330010533678812202354218097512545405947522435258490771167055601360483958644670632441572215539753697817977846174064955149290862569321978468622482839722413756570560574902614079729686524145351004748216637048440319989000889524345065854122758866688116427171479924442928230863465674813919123162824586178664583591245665294765456828489128831426076900422421902267105562632111110937054421750694165896040807198403850962455444362981230987879927244284909188845801561660979191338754992005240636899125607176060588611646710940507754100225698315520005593572972571636269561882670428252483600823257530420752963450";
 int a = 0;
 int b = 1;
 int c = 2;
 int d = 3;
 int z = 0;
while (d <= 1000){
    z = numbers[a] * numbers[b] * numbers[c] * numbers[d];
    store.push_back(z);
    a++;
    b++;
    c++;
    d++;


}

    std::cout << *std::max_element(store.begin(), store.end()) << std::endl;

}

编辑:问题是我必须找到该系列中连续13位数的最大产品,对不起忘了先写它。

2 个答案:

答案 0 :(得分:0)

numbersstd::string,每个元素都是char。要将数字char'0' .. '9')转换为实际的整数值(0 .. 9),您需要减去{{1} }:

'0'

答案 1 :(得分:0)

你的问题是#pragma omp parallel for private(counter)没有给你一个整数,而是给你一个代表整数的字符。因此,对于您的示例,第一次拨打numbers[a]时,numbers[a]不是'7'7可以转换为'7',它将具有字符集中包含的字符代码的值。在ASCII中将是37.您需要做的是从字符中减去int以将其转换为int。因此,如果您这样做,代码看起来像

'0'

这是因为z = (numbers[a] - '0') * (numbers[b] - '0') * (numbers[c] - '0') * (numbers[d] - '0'); 保证在c ++使用的所有字符集中都有比'7'大7个字符的字符代码。