标题:萌新求助,用递归算法进行进制转化出现的问题
只看楼主
凌若寒曦
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



参与讨论请移步原网站贴子:https://bbs.bccn.net/thread-483439-1-1.html




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

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