Welcome to collectivesolver - Programming & Software Q&A with code examples. A website with trusted programming answers. All programs are tested and work.

Contact: aviboots(AT)netvision.net.il

Buy a domain name - Register cheap domain names from $0.99 - Namecheap

Scalable Hosting That Grows With You

Secure & Reliable Web Hosting, Free Domain, Free SSL, 1-Click WordPress Install, Expert 24/7 Support

Semrush - keyword research tool

Boost your online presence with premium web hosting and servers

Disclosure: My content contains affiliate links.

39,974 questions

51,918 answers

573 users

How to sum the digits of the number 2^N in C

1 Answer

0 votes
#include <stdio.h>
#include <string.h>

#define MAX_DIGITS 4096  // Enough to hold 2^1000

void calculate2PowerNAsString(int N, char result[]) {
    // Calculate 2^N as a string for large numbers
    result[0] = '1';
    result[1] = '\0';
    int len = 1;

    for (int i = 0; i < N; i++) {
        int carry = 0;
        for (int j = 0; j < len; j++) {
            int num = (result[j] - '0') * 2 + carry;
            result[j] = (num % 10) + '0';
            carry = num / 10;
        }
        while (carry > 0) {
            result[len++] = (carry % 10) + '0';
            carry /= 10;
        }
        result[len] = '\0';
    }
}

int sumOfDigits(int N) {
    char result[MAX_DIGITS];
    calculate2PowerNAsString(N, result);

    int sum = 0;
    for (int i = 0; result[i] != '\0'; ++i) {
        sum += (result[i] - '0');
    }

    return sum;
}

int main() {
    int N;

    N = 15;
    printf("Sum of digits of 2^%d is: %d\n", N, sumOfDigits(N));

    N = 100;
    printf("Sum of digits of 2^%d is: %d\n", N, sumOfDigits(N));

    N = 1000;
    printf("Sum of digits of 2^%d is: %d\n", N, sumOfDigits(N));

    return 0;
}



/*
run:

Sum of digits of 2^15 is: 26
Sum of digits of 2^100 is: 115
Sum of digits of 2^1000 is: 1366

*/



 



answered Aug 1, 2025 by avibootz
edited Aug 2, 2025 by avibootz
...