设计一个程序打印出所有水仙花数 c语言
时间: 2023-07-15 16:12:29 浏览: 44
水仙花数是指一个 n 位正整数 (n≥3),它的每个位上的数字的 n 次幂之和等于它本身。
例如:1^3 + 5^3 + 3^3 = 153,因此 153 就是一个水仙花数。
以下是一个 C 语言程序,用于打印出所有的三位数水仙花数:
```c
#include <stdio.h>
#include <math.h>
int main()
{
int i, num, digit, sum;
printf("All three-digit Narcissistic numbers are:\n");
for (i = 100; i <= 999; i++)
{
num = i;
sum = 0;
while (num > 0)
{
digit = num % 10;
sum += pow(digit, 3);
num /= 10;
}
if (sum == i)
{
printf("%d\n", i);
}
}
return 0;
}
```
该程序通过循环遍历所有三位数,对每个数进行水仙花数判断,并输出结果。其中,pow() 函数用于计算数字的 n 次幂。
相关问题
用C语言打印出所有水仙花数
水仙花数是指一个n位数(n≥3),其各位数字的n次方之和等于该数本身。例如153=1^3+5^3+3^3,所以153是一个水仙花数。
以下是用C语言打印出所有水仙花数的代码:
```c
#include <stdio.h>
int main() {
int i, j, k, num;
for (i = 1; i <= 9; i++) {
for (j = 0; j <= 9; j++) {
for (k = 0; k <= 9; k++) {
num = i * 100 + j * 10 + k;
if (num == i * i * i + j * j * j + k * k * k) {
printf("%d\n", num);
}
}
}
}
return 0;
}
```
该程序的思路是通过三层循环依次枚举所有的三位数,计算出该数的各位数字的立方和,判断是否等于该数本身,如果是则输出该数。
用c语言编写打印出所有“水仙花数”的程序
水仙花数是指一个n位数(n≥3),它的每个位上的数字的n次幂之和等于它本身。例如,153是一个水仙花数,因为1^3 + 5^3 + 3^3 = 153。
以下是用C语言编写打印出所有水仙花数的程序:
```c
#include <stdio.h>
int main() {
int i, j, k, n;
for (n = 100; n < 1000; n++) {
i = n / 100; // 获取百位数
j = n / 10 % 10; // 获取十位数
k = n % 10; // 获取个位数
if (n == i * i * i + j * j * j + k * k * k) {
printf("%d\n", n);
}
}
return 0;
}
```
在上面的程序中,我们使用了一个循环来遍历所有的三位数,然后获取每个数的百位、十位和个位数字,计算它们的三次方之和,如果等于这个数本身,则打印出这个数。