寻找水仙花数 C语言
时间: 2024-09-23 14:16:42 浏览: 43
水仙花数c语言程序.docx
寻找水仙花数是一个经典的编程题目,涉及到了数学的概念。水仙花数是指那些每一位数字的立方和等于其本身的三位数。例如,153就是一个水仙花数,因为 1^3 + 5^3 + 3^3 = 1 + 125 + 27 = 153。
在C语言中,你可以编写一个函数来检查给定的整数是否是水仙花数。以下是一个简单的示例代码:
```c
#include <stdio.h>
// 函数定义
int is_armstrong(int num) {
int original_num, remainder, sum = 0;
original_num = num;
// 把数字分解并计算每个位的立方和
while (num != 0) {
remainder = num % 10; // 取余数得到最后一位
sum += pow(remainder, 3); // 立方并累加
num /= 10; // 移除最后一位
}
// 检查原数是否等于立方和
return (original_num == sum);
}
int main() {
int number, i;
printf("Enter a three-digit number to check for Armstrong number: ");
scanf("%d", &number);
if (is_armstrong(number)) {
printf("%d is an Armstrong number.\n", number);
} else {
printf("%d is not an Armstrong number.\n", number);
}
// 询问用户是否继续查找更多
printf("Do you want to check more numbers? (yes/no): ");
char response[10];
scanf("%s", response);
if(strcmp(response, "yes") == 0) {
for(i = number + 1; ; i++) { // 使用循环无限查找更大的水仙花数
if(is_armstrong(i)) {
printf("%d is also an Armstrong number.\n", i);
} else {
break;
}
}
}
return 0;
}
```
阅读全文