How to find the first integer equal to the sum of its digits raised to some power in C

1 Answer

0 votes
#include <stdio.h>

/* compute sum of digits */
long long digitSum(long long n) {
    long long s = 0;

    while (n > 0) {
        s += n % 10;
        n /= 10;
    }

    return s;
}

int main(void) {
    for (long long n = 2; ; n++) {
        long long s = digitSum(n);

        // Try powers k = 2..10 (enough for reasonable ranges)
        long long p = s * s;
        for (int k = 2; k <= 10; ++k) {
            if (p == n) {
                printf("Found: %lld = (%lld)^%d\n", n, s, k);
                return 0;
            }
            p *= s; // next power
        }
    }
}


/*
run:

Found: 81 = (9)^2

*/

 



answered 2 days ago by avibootz
edited 1 day ago by avibootz

Related questions

...