大橙子网站建设,新征程启航

为企业提供网站建设、域名注册、服务器等服务

c语言求水仙花数的函数 c语言中用函数求水仙花数

c语言求水仙花数

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

创新互联建站科技有限公司专业互联网基础服务商,为您提供珉田数据中心高防主机,成都IDC机房托管,成都主机托管等互联网服务。

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()

{

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语言调用函数求水仙花数

int li(int n)

{ return n*n*n;

}

int shuixian(int n)

{

int b,s,g;

b=n/100;

s=n/10%10;

g=n%10;

if((li(b)+li(s)+li(g))==n)

return 1;

return 0;

}

int main()

{

int i;

scanf("%d",i);

if(shuixian(i))

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

return 0;

}

c语言求水仙花数!!!!

你在定义变量的时候多定义一个整型变量

count用来计数;count初值设为0

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

printf("%d\t",i);

在if里再加一条语句,count=count+1;即

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

{

printf("%d\t",i);

count=count+1}

printf("水仙花的个数为:%d",count);

就可以了

C语言求水仙花数

pow(a_ge,3);改为pow((double)a_ge,3),pow()第一个参数需为double类型

//计算100-1000之间水仙花数

#include "stdio.h"

void main()

{

int i,m,k,s ;

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

{

m = i;

s = 0;

while(m  0)

{

k = m % 10;

s = s + k * k * k;

m = m / 10;

}

if(s == i)

printf("%5d",i);

}

printf("\n");

}


分享名称:c语言求水仙花数的函数 c语言中用函数求水仙花数
本文网址:http://dzwzjz.com/article/doojpeh.html
在线咨询
服务热线
服务热线:028-86922220
TOP