-
-
Notifications
You must be signed in to change notification settings - Fork 4.4k
/
Copy pathsol1.c
62 lines (53 loc) · 1.55 KB
/
sol1.c
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
/**
* \file
* \brief [Problem 16](https://projecteuler.net/problem=16) solution
* \author [Krishna Vedala](https://github.com/kvedala)
*/
#include <math.h>
#include <stdint.h>
#include <stdio.h>
#include <stdlib.h>
/** Main function */
int main(int argc, char **argv)
{
const double tmp = log(10) / log(2); /* required to get number of digits */
unsigned long MAX_NUM_DIGITS;
uint8_t *digits =
NULL; /* array to store individual digits. index 0 = units place */
int N = 1000, sum = 0;
if (argc == 2)
N = atoi(argv[1]);
MAX_NUM_DIGITS = (N + tmp) / tmp;
digits = calloc(MAX_NUM_DIGITS, sizeof(uint8_t));
digits[0] = 1;
if (!digits)
{
perror("Unable to allocate memory!");
return -1;
}
for (int i = 0; i < N; i++)
{
int carry = 0;
for (int j = 0; j < MAX_NUM_DIGITS; j++)
{
digits[j] = (digits[j] << 1) + carry; /* digit * 2 + carry */
// printf("\t value: %d\t", digits[j]);
if (digits[j] > 9)
{
carry = 1;
digits[j] -= 10;
}
else
carry = 0;
// printf("carry: %d\t value: %d\n", carry, digits[j]);
/* accumulate sum for last multiplication */
if (i == N - 1)
sum += digits[j];
}
}
printf("2^%d = ", N);
for (int i = MAX_NUM_DIGITS - 1; i >= 0; i--) putchar(digits[i] + 0x30);
printf("\n\t Sum: %d\t Num. digits: %lu\n", sum, MAX_NUM_DIGITS);
free(digits);
return 0;
}