c语言水仙花数代码5位数(c语言水仙花数100999)

http://www.itjxue.com  2023-03-19 01:13  来源:未知  点击次数: 

c语言水仙花数

#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.求得这三个数字的立方和是否与其本身相等,若相等,则该数为水仙花数。

参考资料:

百度百科-水仙花数

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

1、首先需要打开Dev-c++软件,点击“新建源代码”。

2、然后按照如图所示填写代码。

3、其中:a表示的是水仙花数的百位数,b表示的是水仙花数的十位数,c表示的是水仙花数的个位数,sum表示的是所有累加下来的水仙花数。

4、if(sum==a*a*a+b*b*b+c*c*c)这一个程序步骤的作用是在规定查找的范围内找到符合这个条件的数。

5、注意a,b,c,sum的运算过程都是要在for 循环内完成,不可以在外循环进行。

6、而且还要注意区分在赋予百位数、十位数、个位数的计算用的“/","%”的区别,“/”表示除后取整数,“%”表示除后取余数。

7、最后点击“运行”即可得出要找的结果了。

“水仙花数”C语言程序

代码如下:

#include stdio.h

int main()

{

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

int i=100;

for( ; i1000; 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。

参考资料:

百度百科——水仙花数

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

c语言中,如何输出所有的水仙花数 水仙花数即三位的自幂数。所谓自幂数,就是指一个 n 位数 ( n≥3 ),其每位上的数字的 n 次幂之和等于本身。

所以水仙花数,首先是三位数,形式为abc,同时a,b,c的立方和值与原本数相同。

类似的还有

四位自幂数:四叶玫瑰数

五位自幂数:五角星数

六位自幂数:六合数

等等。

对于水仙花数的判断,需要按照以下步骤:

1 提取该数的个位,十位,百位值。

2 计算三个数的立方和。

3 与原值比较,如相等则是。

要输出所有水仙花数,需要:

1 对所有三位数,即100到999遍历;

2 对每个数判断是否为水仙花数,如是则退出。

当回圈结束,所有的水仙花数就输出成功了。

程式码如下:

int isNarcissistic(int n)

{

int a = n/100;

int b = n/10%10;

int c = n%10;

return a*a*a + b*b*b + c*c*c == n;

}

int main()

{

int i;

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

if(isNarcissistic(i)) printf("%d ",i);

}

输出结果如下:

153 370 371 407

c语言中水仙花数

这是列印1000以内的水仙华数

#includestdio.hint main(){ int i,a,b,c; for(i=100;i1000;i++) { a=i/100; b=(i/10)%10; c=i%10; if((a*a*a+b*b*b+c*c*c)==i) printf("%d\n",i); } return(0);}

50分~用QB语言输出所有水仙花数

For n = 100 To 999

i = Int(n / 100)

j = Int((n - i * 100) / 10)

k = n Mod 10

If i ^ 3 + j ^ 3 + k ^ 3 = n Then Print n,

Next

C语言怎样编输出所有水仙花数范围100到999

水仙花数是指一个 n 位数 ( n≥3 ),它的每个位上的数字的 n 次幂之和等于它本身。判断一个数是否为水仙花数需要拆分数位,求幂再相加。不过这道题限定了范围,都是三位数,所以可以使用3重回圈分别代表3个数位,这样就省去了拆分的麻烦。

程式码如下:

#include stdio.h

int main()

{

int i, j, k, sum;

sum = 0;

for (i = 1; i 10; i++)

for (j = 0; j 10; j++)

for (k = 0; k 10; k++)

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

printf("%d\n", i*100 + j*10 + k);

return 0;

}

输出0-999中的所有的 水仙花数

水仙花数至少要3位数,所以0-999相当于100-999:

@echo off

Setlocal EnableDelayedExpansion

for /l %%a in (100 1 999) do (

for %%a in (%%a/100 %%a%%100/10 %%a%%10) do set/a "x+=%%a*(%%a*(%%a))"

if %%a equ !x! echo %%a

set "x="

)

pause

另存为x.bat双击执行。。

用c#设计程式,输出所有的水仙花数

◆C# ASP.NET 中的实现程式码

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

{

int bai = 0;

int shi = 0;

int ge = 0;

int baiyushu = 0;

bai = i / 100;

baiyushu = i % 100;

shi = baiyushu / 10;

ge = baiyushu % 10;

if (i == bai * bai * bai + shi * shi * shi + ge * ge * ge)

{

Response.Write("水仙花数:" + i + "br");

}

}

C语言中,水仙花数怎么做

main()

{float a,b,c,i

for(i=100;i=999;i++)

{a=i/100;

b=s/10-a*10;

c=i%10;

if(i=a*a*a+b*b*b+c*c*c)

}

print("%d",i);

}

如何求所有的水仙花数。

1. 首先你这程式中少了x++;这条语句,会进入死回圈的

2. if(a*a*a=b*b*b+c*c*c==x) "等号"写错了,改成 if(a*a*a+b*b*b+c*c*c==x)

3. printf(%d\n",x); 少了个双引号 改成 printf("%d\n",x);

还有除了这种方法外还有其他好的方法吗?

演算法部分可以改改

a=x/100;

b=(x-a*100)/10;

c=x-a*100-b*10;

改成

a=x/100;

c=x%10; 求余数,得到个位数,

b=x/10; 去掉个位数,

b=b%10; 求余数,得到十位数,

我用回圈写了个程式,可以参考下:

#includestdio.h

int main()

{

int i,a,b,c;

for(i=100;i=999;++i)

{

a=i%10;

b=i/100;

c=i/10;

c=c%10;

if(a*a*a+b*b*b+c*c*c==i)printf("%d\n",i);

}

getch();

return 0;

}

c语言输出所有得水仙花数,玫瑰花数和五角星数

水仙花数即三位的自幂数。所谓自幂数,就是指一个 n 位数 ( n≥3 ),其每位上的数字的 n 次幂之和等于本身。

所以水仙花数,首先是三位数,形式为abc,同时a,b,c的立方和值与原本数相同。

类似的还有

四位自幂数:四叶玫瑰数

五位自幂数:五角星数

六位自幂数:六合数

等等。

对于水仙花数的判断,需要按照以下步骤:

1 提取该数的个位,十位,百位值。

2 计算三个数的立方和。

3 与原值比较,如相等则是。

要输出所有水仙花数,需要:

1 对所有三位数,即100到999遍历;

2 对每个数判断是否为水仙花数,如是则退出。

当回圈结束,所有的水仙花数就输出成功了。

程式码如下:

int isNarcissistic(int n)

{

int a = n/100;

int b = n/10%10;

int c = n%10;

return a*a*a + b*b*b + c*c*c == n;

}

int main()

{

int i;

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

if(isNarcissistic(i)) printf("%d ",i);

}

如何用C语言求所有水仙花数之和?

# include stdio.h

void main()

{

int m,n,a,b;

int sum=0;对总和初始化

for(m=100;m1000;m++)

{

n=m/100;

a=m%100/10;

b=m%10; for回圈

if(m==n*n*n+a*a*a+b*b*b)

printf("%d\n",m);

sum=sum+m;如果是水仙花数就显示这个数并加到sum中

}

printf("%d\n",sum);寻找结束后显示sum

}

水仙花数的c语言编程。

所谓的“水仙花数”是指一个三位数其各位数字的立方和等于该数本身,例如153是“水仙花数”,因为:153 = 1^3 + 5^3+ 3^3?。

下面是完整的C语言编程代码:

运行结果:

result is:153? 370? 371? 407

扩展资料

常见水仙花数

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

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

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

5位水仙花数c语言

水仙花数好像是指一个n位数(n=3)的各个位的n次方的和等于这个数,那这个数就是水仙花数。在百度百科上有介绍的,上面也有程序。

#includestdio.h

void main()

{

int n,s,sum=0,i;

for(i=10000;i=100000;i++) /*所以你这里可以直接从i=10000开始,,*/

{

do {

n=i;

s=n%10;

n=n/10;

sum=sum+s*s*s*s*s;

}

while(n!=0);

if(i==sum);

printf("%-6d ",sum);

}

}

(责任编辑:IT教学网)

更多

推荐其他源码文章