水仙花数(一般指三位数)是指一个N位正整数(N≥3),它的每个位上的数字的N次幂之和等于它本身。例如:153=13+53+33。 本题要求编写程序,计算所有N位水仙花数。
#include<stdio.h>
#include<math.h>
int main() {
//水仙花
//输入3<=N<=7,输出N位水仙花数
int n;
scanf("%d",&n);
int i,j;
int s[10];
for(i=0; i<10; i++)
s[i]=pow(i,n);
for(j=pow(10,n-1); j<pow(10,n); j++) {
int temp=j;
int sum=0;
while(temp>0) {
sum+=s[temp%10];
temp/=10;
}
if(sum==j)
printf("%d\n",sum);
}
return 0;
}
如判断一个三位数是否是水仙花数例子
#include<stdio.h>
#include<math.h>
int main()
{
int n;
scanf("%d",&n);
int x=n;
int sum=0;
while(x)
{
sum+=pow(x%10,3);
x/=10;
}
if(sum==n)
printf("OK");
else
printf("no");
return 0;
}
该博客提供了两个C语言程序示例,分别用于计算指定范围内(3到7位数)的所有水仙花数和判断一个三位数是否为水仙花数。水仙花数是指各位数字的N次幂之和等于其本身的正整数。程序通过循环和数学运算实现这一判断,并输出符合条件的水仙花数。

149

被折叠的 条评论
为什么被折叠?



