如何用C语言求水仙花数
#include <stdio.h> int main {int i,a,b,c; for(i=100;i<1000;i++) a=i%10; b=(i%100–i%10)/10; c=(i–i%10–b*10)/100 if(i==a*a*a+b*b*b+c*c*c) printf(“i是水仙花数字”); return 0;}
C语言求助:求1000以内的水仙花数
#include<iostream>usingnamespacestd;voidmain(){intm=1,n=0,x=0;cout<<"1000以内的所有水仙花数数:"<<endl;;for(;m<=1000;m++){x=m/100;n+=x*x*x;x=m%100/10;n+=x*x*x;x=m%100%10;n+=x*x*x;if(n==m){cout<<m<<"\t";}n=0;}cout<<endl;}
1000以内的水仙花数代码
水仙花数,指的是一个三位数(100-999),其个位、十位、百位数的立方和等于该数本身。例如:153 = 1³ + 5³ + 3³。
下面是求1000以内的水仙花数的Python代码:
```
for i in range(100, 1000):
sum = 0
temp = i
while temp > 0:
digit = temp % 10
sum += digit ** 3
temp //= 10
if i == sum:
print(i)
```
首先,从100到999遍历三位数。然后,用temp保存当前遍历的数i,以便计算其个位、十位、百位的立方和。接着,用while循环,取temp的个位数,计算其立方和,并将temp除以10去掉个位数。循环直到temp小于等于0,完成对i每个位数立方和的计算。最后,与i比较,若相等,则输出i,即这个三位数是一个水仙花数。
这个代码中,最关键的就是while循环,此循环从temp中取出了三位数每一位数的值,实现了算法的核心计算。
用C语言求1000以内的水仙花数可以用for循环。
可以参考下面的代码:
#include<stdio.h>
main()
{
int i=0,g,s,b,a=0;
for(i=0;i<1000;i++)
{
if(i>=100&&i<=999)
{
b=i/100;
s=(i-b*100)/10;//除10
g=i-b*100-s*10;
a=b*b*b+s*s*s+g*g*g;
}
if(a==i)printf("%d\n",a);
}
}
扩展资料:
for循环语法
1、语句最简形式为:
for( ; ; )
2、一般形式为:
for(单次表达式;条件表达式;末尾循环体)
{
中间循环体;
}
其中,表示式皆可以省略,但分号不可省略,因为“;”可以代表一个空语句,省略了之后语句减少,即为语句格式发生变化,则编译器不能识别而无法进行编译。

