c语言水仙花数

Posted

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了c语言水仙花数相关的知识,希望对你有一定的参考价值。

#include<stdio.h>
int main()
int i,a=i/100,
b=(i%100)/10,
c=i%10;
for(i=100;i<=999;i++)

if(i==a*a*a+b*b*b+c*c*c)break;
printf("%d is right\n",i);
return 0;
菜鸟求解
为什么错了

#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;

扩展资料:

需要注意的地方:

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

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

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

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

参考资料:

百度百科-水仙花数

参考技术A

C语言输出水仙花数的具体分析和实现流程如下:

1、水仙花数的含义

“水仙花数”是一个三位数其各位数字的立方和等于该数本身。例如:3^3 + 7^3+ 0^3 = 370

2、算法分析

把给出的某个三位数的个位、十位、百位分别拆分,并求其立方和(设为sum),若sum与给出的三位数相等, 则为“水仙花数”。

3、算法设计

“水仙花数”是一个三位数,可以确定该数的取值范围是 100〜999。对应的循环条件如下:

for (n=10; n<1000; n++)

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

将(n-i*100)整除以10, 得出n在十位上的数字t。

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

求得h,t,a 三个数字的立方和是否与n相等,如果相等则证明该数为水仙花数。

4、代码实现

#include <stdio.h>

int main()

int h, t, a, n;

printf("result is:");

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

h = n / 100;

t = (n-h*100) / 10;

a = n % 10;

if (n == h*h*h + t*t*t + a*a*a)  /*各位上的立方和是否与原数n相等*/

printf("%d  ", n);

printf("\\n");

return 0;

扩展资料:

常见水仙花数

水仙花数又称阿姆斯特朗数。

1、三位的水仙花数共有4个:153,370,371,407;

2、四位的四叶玫瑰数共有3个:1634,8208,9474;

3、五位的五角星数共有3个:54748,92727,93084;

4、六位的六合数只有1个:548834;

5、七位的北斗七星数共有4个:1741725,4210818,9800817,9926315;

6、八位的八仙数共有3个:24678050,24678051,88593477

参考资料来源:百度百科-水仙花数

参考技术B

案例:利用for循环控制100-999个数,每个数分解出个位,十位,百位

#include <stdio.h>

int main()


int i,j,k,n;

printf("'water flower'number is:");

for(n=100;n<1000;n++)

i=n/100;/*分解出百位*/

j=n/10%10;/*分解出十位*/

k=n%10;/*分解出个位*/

if(i*100+j*10+k==i*i*i+j*j*j+k*k*k)

printf("%-5d",n);

printf("\\n");

定义

    水仙花数:指一个三位数,其各位数字立方和等于该数本身。

    例:153是一个“水仙花数”,因为153=1的三次方+5的三次方+3的三次方。

参考资料

水仙花数的c语言编程。.百度[引用时间2018-5-8]

谭浩强.c语言程序设计.北京:清华大学出版杜,2000

参考技术C

水仙花数完整代码如下:

#include <stdio.h>

int main()

int hun, ten, ind, n;

printf("结果是:");

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;

“水仙花数”又称为“阿姆斯特朗数”。如果一个n(n≥3)位数的各位数字的n次幂之和等于该数本身,则该数称为“水仙花数”。

参考技术D //以下找水仙花数的方法尽可能写的基础,所以显得有点啰嗦,但很适合初学者理解
#include <stdio.h>
#include <math.h>
int main()

int number, a, b, c, i, num;
int count=0, sum = 0
printf ("请输入一个数:");
scanf ("%d",&number);
//确定位数
a=number;
while (a)

a /= 10;
count++; //位数

//拆位进行累加

c = number;
while (c)

num = c % 10;
c = c /10;
b=1;

//以下的步骤其实可以使用sum += pow(num,count);代替

for (i=0; i<count; i++)
b *= num;
sum +=b;


//进行判断

if (sum == number)
printf("%d是水仙花数\n",number);
else
printf("%d不是水仙花数\n",number);
return 0;

c语言:遍历水仙花数n,判断是不是为素数,并返回结果。

参考技术A LZ你好~
首先你要理解啥是水仙花数:

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

以上来自百度百科。

按照楼主的程序,有3层循环,姑且叫做a循环,b循环,c循环。
我们先从循环上下界和条件来看:
楼主用a循环代表个位数,用b循环代表10位数,c循环代表百位数,对嘛?假设是这种情况,让我们先不看代码。
事实上a循环是最外面的循环,c循环是最里面的循环,而计数按照逻辑应该是 111,112,113这样增长的,所以逻辑上应该反过来,a代表百位数,b代表10位数,c代表个位数。(其实您的方式也可以遍历所有您想遍历的数,只不过从逻辑上变成111,211,311...911,121,221...这样了,但是不觉得很不舒服嘛~)
然后我们来分析代码,结构很明白了:
a循环,百位数

b循环,十位数

c循环,个位数

验证







然后我们来确定验证:
一个水仙花数n,假设是1000以内的3位数,写作abc也就是 n = a*100 + b*10 + c = a^3 + b^3 + c^3,这不就是验证条件嘛?所以条件就是a*100 + b*10 + c = a*a*a + b*b*b + c*c*c;

然后来看循环上下界,百位数可以从1-9,十位数可以从0-9,个位可以从0-9,这时候程序就完成了啦。

楼主在确定上下界的时候犯了错哦,十位数不可以当做10到99,你要单纯的将她看成数字,因为十位数只可能出现0-9,这10种情况,而不会出现11,23,56这样的情况吧?

所以关键的循环体应该是:

for(a=1;a<=9;a++)

for(b=0;b<=9;b++)

for(c=0;c<=9;c++)

if(a*100 + b*10 + c == a*a*a + b*b*b + c*c*c)

printf("%d,%d,%d\n",a,b,c);









我把大括号全带上了,请养成良好的编程习惯哦~
当然你也可以把最后验证部分(if部分)替换成三元表达式,使用某一些编译器效率会提高一点:

for(a=1;a<=9;a++)
for(b=0;b<=9;b++)
for(c=0;c<=9;c++)
a*100 + b*10 + c == a*a*a + b*b*b + c*c*c ? printf("%d,%d,%d\n",a,b,c):; // 注意有个':'

以上是关于c语言水仙花数的主要内容,如果未能解决你的问题,请参考以下文章

C语言编程输出所有的“水仙花数”。

C语言找出最大水仙花数(水仙花数是3位整数,且各位立方之和等于该数,如153就是水仙花数)

“水仙花数”C语言程序

C语言 水仙花数 编程题

c语言中,如何输出所有的水仙花数

c语言编程题 找出所有的水仙花数,水仙花数是指一个3位数