>凡事网 导航

c语言水仙花数 “水仙花数”C语言程序

2024-07-01m.fan-pin.com
水仙花数的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
参考资料:百度百科:水仙花数

代码如下:
#include
int main()
{
printf("输出水仙花数:
");
int i=100;
for( ; i<1000; 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", 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。
参考资料:
百度百科——水仙花数

#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("
");

}

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、水仙花数的含义

“水仙花数”是一个三位数其各位数字的立方和等于该数本身。例如:3^3 + 7^3+ 0^3 = 370

2、算法分析

把给出的某个三位数的个位、十位、百位分别拆分,并求其立方和(设为sum),若sum与给出的三位数相等, 则为“水仙花数”。

3、算法设计

“水仙花数”是一个三位数,可以确定该数的取值范围是 100〜999。对应的循环条件如下:

for (n=10; n<1000; 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; n<1000; 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("
");

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

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



案例:利用for循环控制100-999个数,每个数分解出个位,十位,百位

#include <stdio.h>

int main()

{
int i,j,k,n;

printf("'water flower'number is:");

for(n=100;n<1000;n++)
{

i=n/100;/*分解出百位*/

j=n/10%10;/*分解出十位*/

k=n%10;/*分解出个位*/

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

printf("%-5d",n);

}

}

printf("
");

}



水仙花数完整代码如下:

#include <stdio.h>

int main()

{

int hun, ten, ind, n;

printf("结果是:");

for( n=100; n<1000; n++ )  /*整数的取值范围*/

{

hun = n / 100;

ten = (n-hun*100) / 10;

ind = n % 10;

if(n == hun*hun*hun + ten*ten*ten + ind*ind*ind)  /*各位上的立方和是否与原数n相等*/

printf("%d  ", n);

}

printf("
");

return 0;

}

“水仙花数”又称为“阿姆斯特朗数”。如果一个n(n≥3)位数的各位数字的n次幂之和等于该数本身,则该数称为“水仙花数”。



//以下找水仙花数的方法尽可能写的基础,所以显得有点啰嗦,但很适合初学者理解
#include <stdio.h>
#include <math.h>
int main()
{
int number, a, b, c, i, num;
int count=0, sum = 0
printf ("请输入一个数:");
scanf ("%d",&number);
//确定位数
a=number;
while (a)
{
a /= 10;
count++; //位数
}
//拆位进行累加

c = number;
while (c)
{
num = c % 10;
c = c /10;
b=1;

//以下的步骤其实可以使用sum += pow(num,count);代替

for (i=0; i<count; i++)
b *= num;
sum +=b;

}
//进行判断

if (sum == number)
printf("%d是水仙花数\n",number);
else
printf("%d不是水仙花数\n",number);
return 0;

}

C语言:写一个判断水仙花数的函数,在主函数中输入一个3位的整数,输出其...
include<stdio.h> int isflower(int x) \/\/是 返回1,不是返回0.{ if(x<100 || x>999) \/\/不是三位数 { printf("Input error");return 0;} int a,b,c;a = x%10; \/\/ 个位上的数 b =x\/10%10; \/\/十位上的数 c = x\/100; \/\/百位上的数 if(a*a*a + b*b*b...

C语言:输出100-999中所有水仙花数。
\/\/输出水仙花 voidNarcissusNumber(){for(inti=100;i<1000;i++){ intsum=0;inttemp=i;intrem;for(intj=0;j<3;j++){rem=temp%10;temp\/=10;sum+=rem*rem*rem;}if(sum==i){ printf("%d\\n",i);} } }

C语言 水仙花数
C语言输出水仙花数的具体分析和实现流程如下: 1、水仙花数的含义 “水仙花数”是一个三位数其各位数字的立方和等于该数本身。例如:3^3 + 7^3+ 0^3 = 370 2、算法分析 把给出的某个三位数的个位、十位、百位分别拆分,并求其立方和(设为sum),若sum与给出的三位数相等, 则为“水仙花数”。 3、算法设计...

c语言。。用if语句编程,输入一个三位数,判断是否为水仙花数。
三位的水仙花数就是每一位的立方之和和这个三位数相等的数,用if语句编程,输入一个三位数,判断是否为水仙花数,可以参考以下的代码:include<stdio.h> main(){ int x,a,b,c;scanf("%d",x);a=x\/100;b=(x\/10)%10;c=x%10;if(x==a*a*a+b*b*b+c*c*c)printf("YES");else pri...

C语言的水仙花数,怎么搞?
循环就从10的N-1次方至N次方,比如说N为3,那就是10的2次方(100)至10的3次方(1000){ sum=0;n=i;while(n){ sum+=pow(n%10,N);\/\/计算每一位的N次方的和至sum n=n\/10;} if(sum==i) printf("%d\\n",i);\/\/比较和是否与原数i相等,如果相等则为水仙花数并输出 } } ...

求“水仙花数”,用C语言怎么写?
include "Stdio.h"void main(){ int a,b,c,s;for(a=1;a<10;a++){ for(b=0;b<10;b++){ for(c=0;c<10;c++){ s=100*a+10*b+c;if(s==(a*a*a+b*b*b+c*c*c))printf("%d\\n",s);} } } getchar();}

c语言,水仙花数是指一个N位正整数(N>=3),它每个位上的数字的N次幂之和...
include <stdio.h>#include <math.h>#include <stdlib.h>int main(){double N; \/\/把N从int型定义成double型,因为pow()函数不支持int类型,当然,N是int型也可以,用的时候强制转换也行,但是太烦。int a,t;int i=0,s=0;scanf("%lf",&N); \/\/N是double型了,那么赋值就要用...

用C语言编写判断是否是水仙花数的程序
工具\/材料 VisualStudio2015 首先打开VisualStudio2015软件,新建一个C语言程序,如下图所示 然后我们需要在C语言文件中引入库文件stdio.h,它里面包含了很多后面要使用的函数,如下图所示 接着我们就需要实现水仙花数的判断逻辑,主要是把输入的数字各个位都取出来,然后进行立方求和,最后和输入的数字进行...

c语言,求水仙花数(三位数)。用do while?
以下是使用 C 语言 do-while 循环来求解三位数中的水仙花数的代码:```c include <stdio.h> include <math.h> int main() { int i = 100;do { int a = i \/ 100;int b = i \/ 10 % 10;int c = i % 10;if (i == pow(a, 3) + pow(b, 3) + pow(c, 3)) { printf...

c语言怎么编写水仙花数?
方法:先弄懂什么是水仙花数::水仙花数是指一个n(>=3)位数字的数,它等于每个数字的n次幂之和。3位水仙花数———先定义3个数其中一个为1--9;2个为0--9;(用for循环)再用如果a定义为1--9那么用100*a来表示百位;如果b或者c定义是0--9那么用10*b或者10*c来表示十位;那么下面用...

相关链接2

返回顶部
凡事房车自主流
凡事网