| 网站首页 | 业界新闻 | 小组 | 威客 | 人才 | 下载频道 | 博客 | 代码贴 | 在线编程 | 编程论坛
欢迎加入我们,一同切磋技术
用户名:   
 
密 码:  
共有 1443 人关注过本帖
标题:水仙花数
只看楼主 加入收藏
你要去哪
Rank: 1
等 级:新手上路
帖 子:1
专家分:2
注 册:2013-12-5
收藏
得分:2 
换数据类型
2013-12-05 17:13
亢奋青年
Rank: 2
来 自:遵义市
等 级:论坛游民
帖 子:64
专家分:28
注 册:2013-11-2
收藏
得分:2 
long long BA

my time,my chips.
2013-12-05 21:15
小小战士
Rank: 9Rank: 9Rank: 9
等 级:蜘蛛侠
威 望:1
帖 子:569
专家分:1313
注 册:2012-11-3
收藏
得分:2 
如果数字更大了,那就不能用整形了,可以用字符串实现,说起来简单,做起来有点复杂了,呵呵

小小战士,战士中的战斗机!
2013-12-05 22:30
kebe0412
Rank: 1
来 自:重庆市巴南区
等 级:新手上路
帖 子:4
专家分:2
注 册:2013-12-5
收藏
得分:2 
你可以试着去用一下double,但用法需要讲究一下。
自己去琢磨一下。
double可以到10的300多次方去。
2013-12-05 23:14
kebe0412
Rank: 1
来 自:重庆市巴南区
等 级:新手上路
帖 子:4
专家分:2
注 册:2013-12-5
收藏
得分:0 
你可以试着去用一下double,但用法需要讲究一下。
自己去琢磨一下。
double可以到10的300多次方去。
2013-12-05 23:14
小小战士
Rank: 9Rank: 9Rank: 9
等 级:蜘蛛侠
威 望:1
帖 子:569
专家分:1313
注 册:2012-11-3
收藏
得分:0 
10的300多次方?吓尿我了

小小战士,战士中的战斗机!
2013-12-05 23:49
AVhacker
Rank: 1
等 级:新手上路
帖 子:2
专家分:5
注 册:2013-12-6
收藏
得分:2 
你能把代码贴出来让我们看看么
2013-12-06 13:43
℃Buffer
Rank: 2
等 级:论坛游民
帖 子:25
专家分:48
注 册:2013-2-26
收藏
得分:2 
#include <stdio.h>
#include <math.h>
int is_sxh(int s,int n)
{
    int i;
    long sum=0,j=pow(10,n-1);
    int a[10];
//    printf("j=%d\n",j);
    for(i=0;i<n;i++,j=j/10)
    {
        a[i]=(s/j)%10;
    //    printf("%d\n",a[i]);
    }
    for(i=0;i<n;i++)
    {
        a[i]=pow(a[i],3);
    //    printf("%d\n",a[i]);
        sum=sum+a[i];
    }
    //printf("%d\n",sum);
    if(s==sum)
    {
        return 1;
    }
    else return 0;
}
int pws(long s)
{
    long i;
    int j=3,w;
    for(i=100;i<100000000;i=i*10)
    {
        w=s/i;
        if(w>=1&&w<=9)
        {
            return j;
            break;
        }
        j++;
    }
}
void menu()
{
   
    long s;
    printf("请输入要判断的数(水仙花):");
    scanf("%ld",&s);
    if(is_sxh(s,pws(s)))
    {
        printf("这个数是水仙花数:%ld\n",s);
    }
    else
    {
        printf("这个数不是水仙花数:%ld\n",s);
    }
}
int main()
{
    /*int ch;
    while(1)
    {
        menu();
        printf("是否继续输入(n/y):");
        scanf(" %c",&ch);
        if(ch=='n'||ch=='N')
        {
            break;
        }
    }*/
    long s=1000000;
    for(s=1000000;s<9999999;s++)
    {
        if(is_sxh(s,pws(s)))
        {
            printf("这个数是水仙花数:%ld\n",s);
        }
    }
    printf("验证完毕!\n");
}
2013-12-06 17:05
℃Buffer
Rank: 2
等 级:论坛游民
帖 子:25
专家分:48
注 册:2013-2-26
收藏
得分:0 
但是我验证了你算出的结果,怎么都不是啊!
是不是你算法错了,你可以试试153这下简单的。
2013-12-06 17:07
huncker
Rank: 2
来 自:江苏
等 级:论坛游民
帖 子:11
专家分:15
注 册:2013-8-20
收藏
得分:2 
正如楼上所说,数据类型的事,int不行,你可以换long或者甚至longlong啊
2013-12-08 09:54
快速回复:水仙花数
数据加载中...
 
   



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

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