| 网站首页 | 业界新闻 | 小组 | 威客 | 人才 | 下载频道 | 博客 | 代码贴 | 在线编程 | 编程论坛
欢迎加入我们,一同切磋技术
用户名:   
 
密 码:  
共有 861 人关注过本帖
标题:在范围m和n之间输出其中的水仙花数,如果没有,则输出no!。请问大神这个no我 ...
只看楼主 加入收藏
陈玮毛
Rank: 1
等 级:新手上路
帖 子:1
专家分:0
注 册:2014-4-5
结帖率:0
收藏
已结贴  问题点数:20 回复次数:9 
在范围m和n之间输出其中的水仙花数,如果没有,则输出no!。请问大神这个no我该怎么把它编出来
搜索更多相关主题的帖子: 水仙花 
2014-04-05 19:12
yuccn
Rank: 16Rank: 16Rank: 16Rank: 16
来 自:何方
等 级:版主
威 望:167
帖 子:6815
专家分:42393
注 册:2010-12-16
收藏
得分:3 

我行我乐
公众号:逻辑客栈
我的博客:
https://blog.yuccn. net
2014-04-05 20:23
tlliqi
Rank: 19Rank: 19Rank: 19Rank: 19Rank: 19Rank: 19
等 级:贵宾
威 望:204
帖 子:15453
专家分:65956
注 册:2006-4-27
收藏
得分:3 








.
2014-04-05 20:25
神机军师
Rank: 7Rank: 7Rank: 7
来 自:游鱼潜水
等 级:黑侠
威 望:2
帖 子:202
专家分:542
注 册:2013-12-21
收藏
得分:3 
好吧。。。
呃,我第一个想到的是设定一个int flag的判断变量,初始化为0,如果一有符合要求的出现,就赋值flag = 1.最后输出的时候判断一下flag就行了
嗯,同样可以设定计数变量m,记录水仙花数的个数,最后判定呗~想想流程里面把赋值或者判定加在哪里

呃,当然,我看到帖子我是想你应该把程序已经编出来了。。

[ 本帖最后由 神机军师 于 2014-4-5 23:52 编辑 ]

未知令人期待!
2014-04-05 21:54
leiaoc
Rank: 2
等 级:论坛游民
帖 子:3
专家分:13
注 册:2014-4-5
收藏
得分:3 
不知道
2014-04-05 22:05
ying8501
Rank: 9Rank: 9Rank: 9
等 级:蜘蛛侠
威 望:6
帖 子:1092
专家分:1446
注 册:2008-11-24
收藏
得分:3 
你先把你的程序贴出来,大家帮你改。
2014-04-05 22:22
azzbcc
Rank: 19Rank: 19Rank: 19Rank: 19Rank: 19Rank: 19
来 自:江西财经大学
等 级:贵宾
威 望:81
帖 子:3293
专家分:12919
注 册:2012-11-4
收藏
得分:3 


[fly]存在即是合理[/fly]
2014-04-05 23:04
chqwhlily
Rank: 2
等 级:论坛游民
帖 子:9
专家分:16
注 册:2011-5-11
收藏
得分:3 
//输出m,n之间所有的水仙花数
#include <stdio.h>
#include <math.h>
int count(int);
int sum(int[],int);
void judge(int,int);
int main()
{
    int x,i,m,n,j;
    printf("please input the number:\nm=");
    scanf("%d",&m);
    printf("please input the number:\nn=");
    scanf("%d",&n);
    for(j=m;j<=n;j++)
    {
        i=count(j);   
        judge(j,i);
    }
   

    return 0;
}
void judge(int x,int i)//判断是否是水仙花
{
    int m[10],ss,x1,j;
    x1=x;
    j=i;
    while(i--)
    {
        m[i]=x%10;
        x=x/10;
    }
    ss=sum(m,j);
    if(x1==ss)
    {
        printf("%d\t\n",x1);
    //    c=c+1;
    }
   
}

int sum(int m[],int n)//将数组中存放的各位求幂并相加
{
    int i;
    int y=0;
    for(i=0;i<n;i++)
    {
        y=y+(int)(pow(m[i],n));
   
    }
   
    return y;
}
int count(int n)//判断位数函数
{
    int i=0;
    while(n>0)
    {
        n=n/10;
        i++;
    }

    return i;
}
2014-04-06 11:53
chqwhlily
Rank: 2
等 级:论坛游民
帖 子:9
专家分:16
注 册:2011-5-11
收藏
得分:0 
//输出m,n之间所有的水仙花数
#include <stdio.h>
#include <math.h>
int count(int);
int sum(int[],int);
void judge(int,int);
int main()
{
    int x,i,m,n,j;
    printf("please input the number:\nm=");
    scanf("%d",&m);
    printf("please input the number:\nn=");
    scanf("%d",&n);
    for(j=m;j<=n;j++)
    {
        i=count(j);   
        judge(j,i);
    }
   

    return 0;
}
void judge(int x,int i)//判断是否是水仙花
{
    int m[10],ss,x1,j;
    x1=x;
    j=i;
    while(i--)
    {
        m[i]=x%10;
        x=x/10;
    }
    ss=sum(m,j);
    if(x1==ss)
    {
        printf("%d\t\n",x1);
    //    c=c+1;
    }
   
}

int sum(int m[],int n)//将数组中存放的各位求幂并相加
{
    int i;
    int y=0;
    for(i=0;i<n;i++)
    {
        y=y+(int)(pow(m[i],n));
   
    }
   
    return y;
}
int count(int n)//判断位数函数
{
    int i=0;
    while(n>0)
    {
        n=n/10;
        i++;
    }

    return i;
}
2014-04-06 11:53
water95
Rank: 1
等 级:新手上路
帖 子:21
专家分:0
注 册:2015-4-10
收藏
得分:0 
#include<stdio.h>
#include<math.h>
int pd(int a);
int main()
{
   int m,n,i,as=0,j=0;
  while( scanf("%d%d",&m,&n)!=EOF)
  {
for(i=m;i<=n;i++)
{
  if(pd(i))
  {
      j++;
      if(j==1)
      {
          printf("%d",i);
          as=1;
      }
      else
      {
         printf(" %d",i);
          as=1;
      }
  }
  
}
if(as==0)
printf("no");
  }
return 0;
}
int pd(int a)
 {
 int b,c,d;
 b=a/100;
 c=a%100/10;
 d=a%100%10;
 if(a==b*b*b+c*c*c+d*d*d)
    return 1;
 else
      
 return 0;
   
 }
我是这样写的,提交有错误
2015-05-05 21:42
快速回复:在范围m和n之间输出其中的水仙花数,如果没有,则输出no!。请问大神这 ...
数据加载中...
 
   



关于我们 | 广告合作 | 编程中国 | 清除Cookies | TOP | 手机版

编程中国 版权所有,并保留所有权利。
Powered by Discuz, Processed in 0.017686 second(s), 9 queries.
Copyright©2004-2024, BCCN.NET, All Rights Reserved