十进制转化为二进制结果不对求解

#include <stdio.h>
int main(){
    int n,i,x,a[20],b[20],j;
    n=2;
    scanf("%d",&x);
    b[0]=x;
    a[0]=x%n;
    for(i=1;i<15;i++){
    if(x!=0){
    b[i]=x/n;
    a[i]=b[i]%n;
    x=x/n;
}
}
for(j=15;j>0;j--)
printf("%d",a[j]);    
    return 0;
}

这个计算公式不对吧,应该是不断除2求余数,反过来的就是2进制

点个采纳吧!

你这样十进制转化为二进制的方式是正确的,但是得注意一些细节:

最后输出数组时,你得逆序输出,这才能达到二进制的效果,而且仅仅只能输出存储二进制数那几位。

所以你得这样改:(如果不这样改,就会输出数组多余的乱码)

加多一个变量int k = 0;

if (x != 0) {

    ......

    k++;

}

最后输出:

for (j = k; j > 0; j--)
        printf("%d", a[--k]);

 

这样就可以达到转换的效果了。

您好,我是有问必答小助手,你的问题已经有小伙伴为您解答了问题,您看下是否解决了您的问题,可以追评进行沟通哦~

如果有您比较满意的答案 / 帮您提供解决思路的答案,可以点击【采纳】按钮,给回答的小伙伴一些鼓励哦~~

ps:问答VIP仅需29元,即可享受5次/月 有问必答服务,了解详情>>>https://vip.csdn.net/askvip?utm_source=1146287632

非常感谢您使用有问必答服务,为了后续更快速的帮您解决问题,现诚邀您参与有问必答体验反馈。您的建议将会运用到我们的产品优化中,希望能得到您的支持与协助!

速戳参与调研>>>https://t.csdnimg.cn/Kf0y