水仙花数c语言

Posted

tags:

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

问题描述
春天是鲜花的季节,水仙花就是其中最迷人的代表,数学上有个水仙花数,他是这样定义的: “水仙花数”是指一个三位数,它的各位数字的立方和等于其本身,比如:153=1^3+5^3+3^3。 现在要求输出所有在m和n范围内的水仙花数。
输入
输入数据有多组,第一行是一个正整数t,表示有t组测试数据,每组测试数据输入占一行,包括两个整数m和n(100<=m<=n<=999)。
输出
对于每组测试数据,要求输出所有在给定范围内的水仙花数,就是说,输出的水仙花数必须大于等于m,并且小于等于n,如果有多个,则要求从小到大排列在一行内输出,之间用一个空格隔开; 如果给定的范围内不存在水仙花数,则输出no;每组测试数据的输出占一行。
输入样列
2
100 120
300 380
输出样例
no
370 371

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("\\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

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

参考技术A #include <cstdio>

int x,y;

int main()

int n;
scanf("%d",&n);
for (int j=1;j<=n;j++)

scanf("%d%d",&x,&y);
int u=0;
for (int i=x;i<=y;i++)

int t=i;
int sum=0;
while (t)

sum+=(t%10)*(t%10)*(t%10);
t=t/10;

if (sum==i) printf("%d ",sum),u++;

if (u==0) printf("%s","no");

C语言 水仙花数 编程题

“水仙花数”是指一个三位数,它的各位数字的立方和等于其本身,比如:153=1^3+5^3+3^3。现在要求输出所有在m和n范围内的水仙花数。
(100<=m<=n<=999)。
编程要求,要求编写一个判断水仙花数的函数,在主函数调用该函数判断某个数是否为水仙花数。

输入数据包括两个整数m和n

要求输出所有在给定范围内的水仙花数如果有多个,则要求在一行内输出,之间用一个空格隔开;
如果给定的范围内不存在水仙花数,则输出no;(注意:输出字母为小写)
-- -- - - 下面是我写的,检查了很久 不知道哪里错了 求指导!
#include <stdio.h>
#include <stdlib.h>
#include <math.h>
int judge(int t)

int a,b,c;
a=t/100;
b=(t/10)%10;
c=t%10;
if (t==pow(a,3)+pow(b,3)+pow(c,3)) return 1;
else return 0;

int main()
int m,n,t,p,flag=0;
scanf("%d %d",&m,&n);
t=m;
if (t<=n) p=judge(t);
if(p==1)
printf("%d", t);
printf(" ");
flag=flag+1;
t=t+1;
else t=t+1;
else if(flag==0) printf("no\n");
else printf("\n");

return 0;

你没有循环啊.

if (t<=n)

for(; t<=n; t++)

p=judge(t);
if(p==1)

printf("%d", t);
printf(" ");
flag=flag+1;




else

if(flag==0) printf("no\\n");
else printf("\\n");

参考技术A

#include<stdio.h>
double myPow(double a,int x);//a的x次方。 
int daff(int a);//判断一个数是不是水仙花数。 

double myPow(double a,int x)

    double resu=1;
    int i=0;
    for(i=1;i<=x;i++)
    resu*=a;
    return resu;


int daff(int a) //返回1,表示是水仙花数。0表示不是。 

    int b=a;
    int flag=0;
    int num=0;
    int sum=0;
    while(b)
        
            num=b%10;
            sum+=myPow(num,3);
            b/=10;
        
    if(sum==a)
    flag=1;
    return flag;


int main ()

    int m=0,n=0;
    int i=0;
    int count=0;
    scanf("%d%d",&m,&n);//输入要求m<n. 
    for(i=m;i<=n;i++)
    if(daff(i))
        
            printf("%d ",i);
            count++;
        
    if(count==0)
        printf("no");
    return 0;

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

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

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

“水仙花数”C语言程序

C语言 水仙花数 编程题

c语言中,如何输出所有的水仙花数

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