用C语言求出所有的水仙花数
时间: 2024-12-17 09:45:09 浏览: 14
水仙花数是一个三位数,其各位数字立方之和等于该数本身。例如,153就是一个水仙花数,因为1^3 + 5^3 + 3^3 = 153。在C语言中,你可以通过循环遍历所有三位数并检查条件来找出它们:
```c
#include <stdio.h>
// 检查是否为水仙花数的函数
int is narcissistic(int num) {
int digits[3];
int sum = 0;
// 分离百位、十位和个位
digits[0] = num / 100;
digits[1] = (num % 100) / 10;
digits[2] = num % 10;
// 计算每个位的立方和
for (int i = 0; i < 3; i++) {
sum += pow(digits[i], 3);
}
// 如果和等于原数,就是水仙花数
return (sum == num);
}
int main() {
int start = 100; // 开始查找从100开始的三位数
int end = 999; // 结束于999,包括这个数
printf("水仙花数有:\n");
for (int num = start; num <= end; num++) {
if (is_narcissistic(num)) {
printf("%d ", num);
}
}
printf("\n");
return 0;
}
阅读全文