whppmy 2015-06-25 08:00 采纳率: 66.7%
浏览 1599
已采纳

关于位与运算 求二进制

今天一朋友发我这个代码 输入一个数 然后输出居然是这个数的二进制
我实在看 不懂 求大神解释下 还有 用这种方法能求n进制吗 求指教

 #include<stdio.h>
#include<stdlib.h>
int main()
{
    unsigned int m,temp=1,i;
    temp=temp<<31;
    scanf("%d",&m);
    for(i=1;i<=32;i++)
    {
        putchar(m&temp?'1':'0');
        m=m<<1;
    }
    putchar('\n');
    return 0;
}
  • 写回答

1条回答 默认 最新

  • 江湖贫侠 2015-06-25 08:07
    关注

    temp=temp<<31; //32位系统上int有32位,这是将整数1移到最高位上,

    for(i=1;i<=32;i++)
    {
    putchar(m&temp?'1':'0');
    m=m<<1;
    }

        这段代码是将用户输入的整数m最高位与temp求与,前面提到temp最高位是1,即用m的最高位和1求与并输出。然后将m左移1位,更新最高位。以此运行32次,则将结果转换为2进制。
    
        这个方法不能实现N进制转换
    
    本回答被题主选为最佳回答 , 对您是否有帮助呢?
    评论

报告相同问题?

悬赏问题

  • ¥35 平滑拟合曲线该如何生成
  • ¥100 c语言,请帮蒟蒻写一个题的范例作参考
  • ¥15 名为“Product”的列已属于此 DataTable
  • ¥15 安卓adb backup备份应用数据失败
  • ¥15 eclipse运行项目时遇到的问题
  • ¥15 关于#c##的问题:最近需要用CAT工具Trados进行一些开发
  • ¥15 南大pa1 小游戏没有界面,并且报了如下错误,尝试过换显卡驱动,但是好像不行
  • ¥15 自己瞎改改,结果现在又运行不了了
  • ¥15 链式存储应该如何解决
  • ¥15 没有证书,nginx怎么反向代理到只能接受https的公网网站