“水仙花数”C语言程序

“水仙花数”程序怎么写啊

代码如下:

#include <stdio.h>

int main()

{

printf("输出水仙花数:\n");

int i=100;

for( ; i<1000; i++){

int num_0 = i%10;

int num_1 = i/10%10;

int num_2 = i/10/10%10;

if(i==(num_0*num_0*num_0+num_1*num_1*num_1+num_2*num_2*num_2))

printf("%d\t", i);

}

return 0;

}

扩展资料

自幂数是指一个 n 位数,它的每个位上的数字的 n 次幂之和等于它本身。

n为1时,自幂数称为独身数。显然,0,1,2,3,4,5,6,7,8,9都是自幂数。

n为2时,没有自幂数。

n为3时,自幂数称为水仙花数,有4个:153,370,371,407;

n为4时,自幂数称为四叶玫瑰数,共有3个:1634,8208,9474;

n为5时,自幂数称为五角星数,共有3个:54748,92727,93084;

n为6时,自幂数称为六合数, 只有1个:548834;

n为7时,自幂数称为北斗七星数, 共有4个:1741725,4210818,9800817,9926315;

n为8时,自幂数称为八仙数, 共有3个:24678050,24678051,88593477;

n为9时,自幂数称为九九重阳数,共有4个:146511208,472335975,534494836,912985153;

n为10时,自幂数称为十全十美数,只有1个:4679307774。

参考资料:

百度百科——水仙花数

温馨提示:内容为网友见解,仅供参考
第1个回答  2018-12-14

C语言写水仙花数要将给出的三位数的个位、十位、百位分别拆分,并求其立方和(设为s),若s与给出的三位数相等, 三位数为“水仙花数”,反之,则不是水仙花数。

#include <stdio.h>

int main()

{

int hun, ten, ind, n;

printf("result is:");

for( n=100; n<1000; n++ )  /*整数的取值范围*/

{

hun = n / 100;

ten = (n-hun*100) / 10;

ind = n % 10;

if(n == hun*hun*hun + ten*ten*ten + ind*ind*ind)  /*各位上的立方和是否与原数n相等*/

printf("%d  ", n);

}

printf("\n");

return 0;

}

扩展资料

C语言水仙花数代码设计思想:

1、将n整除以100,得出n在百位上的数字hun。

2、将(n-i*100)整除以10(或将n先整除以10再对10求模n/10%10),得出n在十位上的数字ten。

3、将n对10取余,得出n在个位上的数字ind。

4、求得这三个数字的立方和是否与其本身相等,若相等,则该数为水仙花数。

水仙花数也被称为超完全数字不变数、自恋数、自幂数、阿姆斯壮数或阿姆斯特朗数,水仙花数是指一个 3 位数,它的每个位上的数字的 3次幂之和等于它本身 。

参考资料:百度百科—水仙花数

本回答被网友采纳
第2个回答  2010-06-04
#include "stdio.h"
void main()
{
int a,b,c,i;
for(i=100;i<1000;i++)
{
a=i/100;
b=i%100/10;
c=i%10;
if(a*a*a+b*b*b+c*c*c==i)
printf("%d\t",i);
}
}
以上是100到999内的水仙花数的c程序本回答被提问者采纳
第3个回答  2010-06-04
计算水仙花数,153=1^3+5^3+3^3

#include <stdio.h>
#include <conio.h>
void main()
{
int i,k,z,count=0;

printf("100到999水仙花数:\n");
for(i=101;i<=999;++i)
{ k=i;z=0;
while(k)
{
z+=(k%10)*(k%10)*(k%10);
k/=10;

}

if(z==i)
{printf("%d\t",i);
count++;}
}
printf("\n100到1000有%d个水仙花数\n",count);
getch();
}
第4个回答  2019-12-21
#include <stdio.h>
int main()
{
int start, end, i = 0, a, b, c, size = 0;
while (scanf("%d %d", &start, &end) == 2)
{
for (i = start; i <= end; i++)
{
a = i / 100;
b = i / 10 % 10;
c = i % 10;
//total = pow(c, 3) + pow(a, 3) + pow(b, 3);
if ((a*a*a + b*b*b + c*c*c) == i) //满足水仙花条件
{
if (size == 0) //size=0输出第一个水仙花数
{
printf("%d", i);
}
else //size++输出第二。。第n个水仙花数
{
printf(" %d", i);
}
size++; //个数++;
}
}
if (size == 0) //范围内个数为0,则说明没有满足条件的
{
printf("no");
}
printf("\n");
}
return 0;
}
相似回答