diff options
author | mjfernez <mjfernez@gmail.com> | 2020-02-04 18:48:04 -0500 |
---|---|---|
committer | mjfernez <mjfernez@gmail.com> | 2020-02-04 18:48:04 -0500 |
commit | 6e19bf3ce11c8722e3260c0457f0389193fd9251 (patch) | |
tree | a1dc993afe88e7eab28f927acd457f1085cec4fd | |
parent | b6a758c284fbeb2e2dd7540d34181c8fae92b3ca (diff) | |
download | Project_Euler_Solutions-6e19bf3ce11c8722e3260c0457f0389193fd9251.tar.gz |
fixed productofdigts.c
-rwxr-xr-x | productofdigits | bin | 16736 -> 16680 bytes | |||
-rw-r--r-- | productofdigits.c | 22 |
2 files changed, 13 insertions, 9 deletions
diff --git a/productofdigits b/productofdigits Binary files differindex 814a3c8..9d3f349 100755 --- a/productofdigits +++ b/productofdigits diff --git a/productofdigits.c b/productofdigits.c index e00b801..433c433 100644 --- a/productofdigits.c +++ b/productofdigits.c @@ -21,16 +21,19 @@ const char bigBoy[1001] = "73167176531330624919225119674426574742355349194934" "84580156166097919133875499200524063689912560717606" "05886116467109405077541002256983155200055935729725" "71636269561882670428252483600823257530420752963450"; - -int parseNum(const char *x, int r){ - long len = 1001; - int max = 0; - printf("%s\n", x); +// parseNum: Splits in segements of r, to find out the largest product of digits +// for that segment size +// max is the maximum product found within the number +// x: the number (as a char string) to be parsed +// r: the range to parse over +long long parseNum(const char *x, int r){ + int len = 1000; + long max; for(int i = 0; i < len - r; i++){ // Digits in ascii start at 48 - long long int prod = (long long int) (x[i] - 48); + long long prod = (x[i] - 48); for(int k = i + 1; k < i + r; k++) - prod *= (long long int) (x[k] - 48); + prod *= (x[k] - 48); if(prod > max) max = prod; } @@ -40,7 +43,8 @@ int parseNum(const char *x, int r){ int main(){ - int p = parseNum(bigBoy, 13); - printf("%d\n", p); + long long p = parseNum(bigBoy, 13); + printf("%ld\n", p); + //printf("%ld\n", parseNum(bigBoy, 13)); return 0; } |