c语言编程调用函数求水仙花数

2024-07-10 23:06:40
推荐回答(3个)
回答1:

水仙花数是指耐碧一个 n 位数 ( n≥3 ),每个位上的数字的 n 次幂之和等于它本铅御身。(例如:1^3 + 5^3+ 3^3 = 153)。

所以可以依次通过模除求得每个位上的值,然后做n次幂后相加,再判断是否与本身相等,从而得到是否为水仙花数的结论。

以求所有三位数水仙花数为例,代码如下,其它相似。

#include
#include
#include
int cube(const int n){//计算立方。如果是四位则是四次方,以此类推。
return n*n*n;
}
int isNarcissistic(const int n){//计算是否为水仙花数。
int hundreds=n/100;//百位
int tens=n/10-hundreds*10;//十位
int ones=n%10;//个位
return cube(hundreds)+cube(tens)+cube(ones)==n;//如果相槐亩岩等,则为水仙花数。
}
int main(void){
int i;
for(i=100;i<1000;++i){//对所有三位数判断。
if(isNarcissistic(i))//如果是则输出。
printf("%d\n",i);
}
return 0;
}

回答2:

您好高空,图片并不是很清晰,您能把代码复制下来卜顷给我吗?我帮你看看。我修改了一下·~~望采纳
#include
int main(void)
{
int shuixianhua(int i);
int d,k;
for(k=100;k<=999;k++)
{
d=shuixianhua(k);
if(d==1)
printf("型念陆%d\n",k);
}
}
int shuixianhua(int i)
{
int a,b,c;
a=i/100;
b=i/10%10;
c=i%10;
if(i==a*a*a+b*b*b+c*c*c)
return 1;
else
return 0;
}

回答3:

你缺少大括号,把for后面的包括所有if部分都扩起来,表示一个语句块,才能得到正确的结果