C语言1~10000之间所有水仙花数

Posted

tags:

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

个位数字的立方和等于它本身的数

水仙花数具备“各位数字的位数次方和等于其自身”的性质。遍历1~10000之间可能有解的部分,先测出其数字的位数n,再分离数字的各位,求各位数字的n次方的和便是结果。具体操作可先将要判断的数字转换为数字字符串,这样求其位数和分离数位都极为方便。代码如下:

#include "stdio.h"
#include "string.h"
#include "stdlib.h"
int main(int argc,char *argv[])
int n,m,i,j,k,t;
char a[5];
printf("The results are as follows:\\n");
for(i=1;i<10000;i++)//遍历1~10000部分数据
n=strlen(itoa(i,a,10));//转为数字字符串并计算长度(十进制数位数)n
for(m=j=0;a[j];j++)//分离每一位数字
for(t=1,k=0;k++<n;t*=a[j]-'0');//求每位数字的n次方
m+=t;//求各位数字n次方的和m

if(m==i)//判断是否为"水仙花"
printf("%5d = ",i);//是则输出结果
for(j=0;a[j];printf(j<n-1 ? "%c^%d + " : "%c^%d\\n",a[j++],n));


return 0;

试运行结果如下图:

参考技术A #include "stdio.h"
main()

int a,b,c,d,e,i;
for(i=1;i<=10000;i++)

a=i/10000;
b=i/1000%10;
c=i/100%10;
d=i/10%10;
e=i%10;
if(a*a*a+b*b*b+c*c*c+d*d*d+e*e*e==i)
printf("%6d",i);

参考技术B main() Int a , i; for(i=1 ; i<=10000 ; i++) a=i%10; if (a*a*a==i) printf(“%d/t”,i);

c语言 编程求三位数的水仙花数?

参考技术A #include <stdio.h>

int main()

int i;
for( i=100; i<1000; i++)

int num0 = i%10;
int num1 = i/10%10;
int num2 = i/10/10%10;

if(i==(num0*num0*num0+num1*num1*num1+num2*num2*num2))
printf("%5d", i);


return 0;
本回答被提问者采纳

以上是关于C语言1~10000之间所有水仙花数的主要内容,如果未能解决你的问题,请参考以下文章

用C语言求出100到1000之间的水仙花数?

C语言编程:输出2到100之间的所有素数,每行输出10个

C语言 水仙花数 编程题

C-Free教程之C语言输出水仙花数的方法

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

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