“水仙花数”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。
参考资料:
百度百科——水仙花数
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<=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();
/**
*结果:
*--->153是水仙花数
*--->370是水仙花数
*--->371是水仙花数
*--->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语言程序的主要内容,如果未能解决你的问题,请参考以下文章