c语言打印一个整数的二进制形式

Posted 立体风

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了c语言打印一个整数的二进制形式相关的知识,希望对你有一定的参考价值。

printf函数没有这个功能,如果想打印一个数的二进制形式,就得自己计算。下面是我看到的最简便的算法:

#include <stdio.h>
int main(int argc, char *argv[])
{
    int n=12;
    for(int i=31;i>=0;i--){
        printf("%1d",n&1<<i?1:0);
    }   
    puts("");                                                                                      

    return 0;
}

1、如何理解 n&1<<i?1:0 ,加上括号: (n&(1<<i))?1:0 

2、因为int类型有4个字节,所以也就是32位二进制,从bit0到bit31,所以,1<<i,就是将1位移31,然后和n位与,用于将n的最高位取出,因为取出后如果为0,那么结果就是0,如果为1,结果就是一个正整数,所以这里加了一个问号表达式,来将结果变为0和1。后面的就很明了了。

3、复习一下运算符的优先级。按位与&是9级,移位是6级,问号表达式是14级,所以计算顺序是:移位>>按位与>>问号表达式。正好符合要求,所以一个括号也不用。

以上是关于c语言打印一个整数的二进制形式的主要内容,如果未能解决你的问题,请参考以下文章

C语言-函数递归

C语言 putw 以二进制形式存贮一个整数

c语言输入数字转换成2进制字符串原理

C语言 getw 以二进制形式读取一个整数

c语言中返回无符号整数以二进制位表示的形式

c语言编程如何实现-十进制数转换成二进制和输出