输出水仙花数,输入一个正整数n,输出所有的n位水仙花数 c语言
时间: 2024-10-29 10:09:42 浏览: 16
C语言中的水仙花数,是指一个 n 位数,它的每个位上的数字的n次方之和等于它本身
输出n位水仙花数是指一个n位数,其各位数字立方之和等于它本身。例如,153是一个三位水仙花数,因为1^3 + 5^3 + 3^3 = 153。
在C语言中,你可以使用循环结构遍历指定范围内的所有n位数,并计算它们的立方和来判断是否是水仙花数。以下是一个简单的示例程序:
```c
#include <stdio.h>
#include <stdbool.h>
// 判断是否是水仙花数的函数
bool is_armstrong_number(int num, int n) {
int sum = 0, temp = num;
// 取反向每一位并求和
while (temp > 0) {
int digit = temp % 10;
sum += digit * digit * digit; // 立方和
temp /= 10;
}
// 如果原数等于立方和,则是水仙花数
return num == sum;
}
// 主函数
int main() {
int n;
printf("请输入位数(n): ");
scanf("%d", &n);
for (int i = 100; ; i++) { // 从100开始,防止误判单位数和两位数
if (i >= pow(10, n)) break; // 达到n位就停止
if (is_armstrong_number(i, n)) {
printf("%d ", i); // 输出水仙花数
}
}
return 0;
}
```
阅读全文