| 网站首页 | 业界新闻 | 小组 | 威客 | 人才 | 下载频道 | 博客 | 代码贴 | 在线编程 | 编程论坛
欢迎加入我们,一同切磋技术
用户名:   
 
密 码:  
共有 1061 人关注过本帖
标题:萌新求助,用递归算法进行进制转化出现的问题
只看楼主 加入收藏
凌若寒曦
Rank: 1
等 级:新手上路
帖 子:70
专家分:0
注 册:2017-10-5
结帖率:80%
收藏
已结贴  问题点数:20 回复次数:3 
萌新求助,用递归算法进行进制转化出现的问题
计算十进制转二进制时,输入1023以下的数,一切都正常,如输入1023,得到的结果是1111111111,之后超过1023的数,例如1024,就会显示1410065408这样的数,这是为什么呢?楼下贴代码。
搜索更多相关主题的帖子: 递归算法 进制转 出现 输入 显示 
2017-12-16 16:32
凌若寒曦
Rank: 1
等 级:新手上路
帖 子:70
专家分:0
注 册:2017-10-5
收藏
得分:0 
#include<stdio.h>
long jinzhi(long n);
int main()
{
    long n;
    scanf("%ld",&n);
    printf("%ld",jinzhi(n));
   
    return 0;
}

long jinzhi(long n)
{
    long result;
    long t;
    if(n==1)
     result=1;
    else
    {
    t=n%2;
    result=t+10*jinzhi(n/2);
   }
    return result;
}
2017-12-16 16:32
yangfrancis
Rank: 16Rank: 16Rank: 16Rank: 16
等 级:贵宾
威 望:141
帖 子:1510
专家分:7661
注 册:2014-5-19
收藏
得分:20 
#include<stdio.h>
unsigned _int64 jinzhi(unsigned _int64 n);
int main()
{
    long n;
    scanf("%ld",&n);
    printf("%I64u",jinzhi(n));
   
    return 0;
}

unsigned _int64 jinzhi(unsigned _int64 n)
{
    unsigned _int64 result=0;
    long t;
    if(n==1)
     result=1;
    else
    {
    t=n%2;
    result=t+10*jinzhi(n/2);
   }
    return result;
}
//_int64是64位整数,比long范围大。这样可以勉强解决,但你返回值用数值始终存在隐患,超过_int64的数值范围又会出现不正常的结果。这种题最好用字串接受执行结果
2017-12-16 19:44
凌若寒曦
Rank: 1
等 级:新手上路
帖 子:70
专家分:0
注 册:2017-10-5
收藏
得分:0 
确实呢
2017-12-16 22:29
快速回复:萌新求助,用递归算法进行进制转化出现的问题
数据加载中...
 
   



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

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