int factorial(int n) {
if (n == 0 || n == 1) {
return 1;
}
int result = 1;
for (int i = 2; i <= n; i++) {
result *= i;
}
return result;
}
void interesting(int n) {
int original = n;
int sumFactorial = 0;
while (n > 0) {
int digit = n % 10;
sumFactorial += factorial(digit);
n /= 10;
}
if (sumFactorial == original) {
printf("The number %d is interesting\n", original);
} else {
printf("The number %d is not interesting\n", original);
}
}
主要是红字不太懂,这题主要是判断一个数能不能拆为几个数的阶乘
这段代码主要是一个函数 interesting ,它的作用是判断一个数是否可以拆分为各个位上的数字的阶乘之和等于原数字。红色部分是一个while循环,它的作用是对输入的数字n进行拆分,取出各个位上的数字,然后计算各个位上的数字的阶乘之和。
具体来说,while循环中的 n % 10 是用来取出n的个位数,然后将其传入 factorial 函数计算阶乘,将结果累加到 sumFactorial 中。接着, n /= 10 是将n去掉个位数,继续循环直到n变为0。
最后,通过比较 sumFactorial 和原始输入的数字,来判断这个数字是否“interesting”,即是否能拆分为各个位上的数字的阶乘之和等于原数字。
|