C语言十进制转二进制过程中(通过位移和位与进行操作),同班同学遇到的一些有趣的问题

要求是给定一个-128~127之间的数,输出它的二进制形式

一:解决方法

因为有的朋友单纯来找个代码,复制粘贴,给我点个赞就可以溜了

我给了两种实现,根据需要选一种

#include <stdio.h>
#include <math.h>
#define TIME 8
int  main() {
    printf("输入-128到127之间的一个数\n");
    char num;
    //思路:和0比大小,获取符号位
    while(scanf("%d",&num)){

        for(int i=0;i<TIME;i++){
            //移位实现
            num>=0?printf("0"):printf("1");
            num =num<<1;
            printf("%d\n",num);

            //位与实现
            //num&static_cast<unsigned int>(pow(2, TIME - i-1))?printf("1"):printf("0");

        }
        printf("\n");
    }
    return 0;
}

二:辗转相除法实现(提几个要点,不给出代码了)

下面来说本文的正题了,在写的过程中,我发现有一些同学用的是辗转相除法,每次除以2取余,这样做要考虑,

一:最先的余数要最后输出,要进行数据保存

二:有的位数不足要补0

三:负数的处理会有点问题,负数取余结果是-1或者0,要进行处理一下

我大学上课的时候就是这样做的(这种方法初学者肯定是要写的,符合一般直觉),但是我现在已经记不太清了,最近没写过这个,程序和我有一个能跑就行。csdn有不少这种高质量博文,你得去找找

三:非循环实现(一共也就8位,直接搞)

这是我的一个同学的思路,但他做了半天没得到正确结果,我帮他看看,这也是产生这篇博文的原因

代码如下:

他和我说必须用bcdefgh之类的把值存一下,才不会出问题,但他在给我演示跑一遍的时候,他说的”正确的结果“,在负数方面也不太正确,到下班点了就各回各家了,晚上回家用debug看了看问题大概出在这几个方面

原因都在图里了,很详细,今天早上比较忙,一会还有事我就不再写一遍了(早上抽空摸鱼写博文嘿嘿)

=========================================================================

我虽然给他解决了问题,但我发现在scanf里用%c接收输入的127(127的值对应的char类型是一个未定义的量)时,拿到的值是49(可能不同电脑不一样,我看了一点其他博文,瞎猜的,你们也可以试试),我看了一下内存图,内存里存的是0x7f,转十进制也就是127,目前还没搞清什么情况,有大佬可以评论区给我解答一下,或者等我有空搞明白了再来补后续

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值