“水仙花数”C语言程序

Posted

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了“水仙花数”C语言程序相关的知识,希望对你有一定的参考价值。

“水仙花数”程序怎么写啊

代码如下:

#include <stdio.h>

int main()

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

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\\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。

参考资料:

百度百科——水仙花数

参考技术A

C语言写水仙花数要将给出的三位数的个位、十位、百位分别拆分,并求其立方和(设为s),若s与给出的三位数相等, 三位数为“水仙花数”,反之,则不是水仙花数。

#include <stdio.h>

int main()

int hun, ten, ind, n;

printf("result is:");

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

return 0;

扩展资料

C语言水仙花数代码设计思想:

1、将n整除以100,得出n在百位上的数字hun。

2、将(n-i*100)整除以10(或将n先整除以10再对10求模n/10%10),得出n在十位上的数字ten。

3、将n对10取余,得出n在个位上的数字ind。

4、求得这三个数字的立方和是否与其本身相等,若相等,则该数为水仙花数。

水仙花数也被称为超完全数字不变数、自恋数、自幂数、阿姆斯壮数或阿姆斯特朗数,水仙花数是指一个 3 位数,它的每个位上的数字的 3次幂之和等于它本身 。

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

参考技术B #include "stdio.h"
void main()

int a,b,c,i;
for(i=100;i<1000;i++)

a=i/100;
b=i%100/10;
c=i%10;
if(a*a*a+b*b*b+c*c*c==i)
printf("%d\t",i);


以上是100到999内的水仙花数的c程序本回答被提问者采纳
参考技术C 计算水仙花数,153=1^3+5^3+3^3

#include <stdio.h>
#include <conio.h>
void main()

int i,k,z,count=0;

printf("100到999水仙花数:\n");
for(i=101;i<=999;++i)
k=i;z=0;
while(k)

z+=(k%10)*(k%10)*(k%10);
k/=10;



if(z==i)
printf("%d\t",i);
count++;

printf("\n100到1000有%d个水仙花数\n",count);
getch();
参考技术D #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;

c语言编程题 找出所有的水仙花数,水仙花数是指一个3位数

c语言编程题 找出所有的水仙花数,水仙花数是指一个3位数,其各位数字的立方和刚好等于这三位数本身。

import org.junit.Test;

public class NarcissusNumber

public void isNarcissusNumber()

//循环[100,999]

for(int i=100;i&lt;=999;i++)

//分割出个位

int a=i%10;

//分割出十位

int b=i/10%10;

//分割出百位

int c=i/100;

//判断该数是否等于【个位的三次方+十位的三次方+百位的三次方】

if(i==(Math.pow(a,3)+Math.pow(b,3)+Math.pow(c,3)))

System.out.println(i+"是水仙花数");

Test

public void test()

isNarcissusNumber();

/**

*结果:

*---&gt;153是水仙花数

*---&gt;370是水仙花数

*---&gt;371是水仙花数

*---&gt;407是水仙花数

*/

扩展资料:

import用法

静态的import语句用于导入由另一个模块导出的绑定。无论是否声明了strict mode,导入的模块都运行在严格模式下。在浏览器中,import语句只能在声明了type="module"的script的标签中使用。

此外,还有一个类似函数的动态import(),它不需要依赖type="module"的script标签。

在script标签中使用nomodule属性,可以确保向后兼容。

在您希望按照一定的条件或者按需加载模块的时候,动态import()是非常有用的。而静态型的import是初始化加载依赖项的最优选择,使用静态import更容易从代码静态分析工具和tree shaking中受益。

语法

import defaultExport from"module-name";

import*as name from"module-name";

importexportfrom"module-name";

importexport as aliasfrom"module-name";

importexport1,export2from"module-name";

importfoo,barfrom"module-name/path/to/specific/un-exported/file";

importexport1,export2 as alias2,[...]from"module-name";

import defaultExport,export[,[...]]from"module-name";

import defaultExport,*as name from"module-name";

import"module-name";

var promise=import("module-name");//这是一个处于第三阶段的提案。

defaultExport

导入模块的默认导出接口的引用名。

module-name

要导入的模块。通常是包含目标模块的.js文件的相对或绝对路径名,可以不包括.js扩展名。某些特定的打包工具可能允许或需要使用扩展或依赖文件,它会检查比对你的运行环境。只允许单引号和双引号的字符串。

name

导入模块对象整体的别名,在引用导入模块时,它将作为一个命名空间来使用。

export,exportN

被导入模块的导出接口的名称。

alias,aliasN

将引用指定的导入的名称。

参考技术A

找出所有3位水仙花数的程序:

#include<stdio.h>

int main()

 int i,a,b,c;

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

 

  a=i/100;    //百位数

  b=i/10%10;  //十位数

  c=i%10;     //个位数

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

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

 

 getch();

参考技术B #include<stdio.h>
main()

int i,j,k;
for(i=1;i<=9;i++)
for(j=0;j<=9;j++)
for(k=0;k<=9;k++)
if(100*i+10*j+k==i*i*i+j*j*j+k*k*k)
printf("%d%d%d\n",i,j,k);
本回答被提问者和网友采纳
参考技术C #include"stdio.h"
#include"math.h"
int main()
int i,a,b,c;
for(i=100;i<=999;i++)

a=i%10;

b=i/10%10;

c=i/100;

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


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




return 0;
追问

可以问一些问题吗

追答

说吧。

以上是关于“水仙花数”C语言程序的主要内容,如果未能解决你的问题,请参考以下文章

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

C语言找出最大水仙花数(水仙花数是3位整数,且各位立方之和等于该数,如153就是水仙花数)

求水仙花数c语言

c语言水仙花数

C语言 水仙花数 编程题

用C语言求出100到1000之间的水仙花数?