本篇文章给大家谈谈求水仙花数c语言程序,以及求水仙花数c语言程序do while怎么写对应的知识点,希望对各位有所帮助,不要忘了收藏本站喔。
本文目录一览:
1、水仙花数的c语言编程。2、C语言求水仙花数3、水仙花数C语言程序4、水仙花数c语言5、“水仙花数”C语言程序6、c语言水仙花数
水仙花数的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
参考资料:百度百科:水仙花数
C语言求水仙花数
#includestdio.h
int main(void)
{
int a[4];
int n,m,i,r,s,sum;
int tag=0,j=0;
while(scanf(“%d%d”,n,m)!=EOF)
{
for(i=n;i=m;i++)
{
sum=0;
s=i;
do
{
r=s%10;
sum+=r*r*r;
s=s/10;
}while(s0);
if(sum==i)
{
tag=1;
a[j]=i;
j++;
}
}
if(tag==0)
printf(“no\n”);
else
{
for(i=0;ij;i++)
{
if(i==j-1)
printf(“%d\n”,a[i]);
else
printf(“%d “,a[i]);
}
}
for(i=0;i4;i++)
a[i]=0;
j=0;
tag=0;
}
return(0);
}
———————————————
注意一下最后面不能有空格
ACM的输入必须要scanf(“%d”,n)!=EOF类似这种的格式
水仙花数C语言程序
提示错误可以调试为:
#include stdio.h
int main()
{
int a, b, c, d;
for (a = 100; a 1000; a++)
{
b = a / 100;
c = a % 100 / 10;
d = a % 100 % 10;
if (b*b*b + c*c*c + d*d*d == a)
printf(“水仙花数为%d\n”, a);
}
}
如图为运行结果
原先的错误在于#include后没有加stdio.h,而且for循环语句也有错误。
水仙花数c语言
C语言输出水仙花数的具体分析和实现流程如下:
1、水仙花数的含义
“水仙花数”是一个三位数其各位数字的立方和等于该数本身。例如:3^3 + 7^3+ 0^3 = 370
2、算法分析
把给出的某个三位数的个位、十位、百位分别拆分,并求其立方和(设为sum),若sum与给出的三位数相等, 则为“水仙花数”。
3、算法设计
“水仙花数”是一个三位数,可以确定该数的取值范围是 100〜999。对应的循环条件如下:
for (n=10; n1000; 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; n1000; 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
参考资料来源:百度百科-水仙花数
“水仙花数”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语言水仙花数
#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语言程序和求水仙花数c语言程序do while怎么写的介绍到此就结束了,不知道你从中找到你需要的信息了吗 ?如果你还想了解更多这方面的信息,记得收藏关注本站。