c语言打印一个整数的二进制形式
生活随笔
收集整理的這篇文章主要介紹了
c语言打印一个整数的二进制形式
小編覺得挺不錯(cuò)的,現(xiàn)在分享給大家,幫大家做個(gè)參考.
printf函數(shù)沒有這個(gè)功能,如果想打印一個(gè)數(shù)的二進(jìn)制形式,就得自己計(jì)算。下面是我看到的最簡(jiǎn)便的算法:
#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?,加上括號(hào):?(n&(1<<i))?1:0?
2、因?yàn)閕nt類型有4個(gè)字節(jié),所以也就是32位二進(jìn)制,從bit0到bit31,所以,1<<i,就是將1位移31,然后和n位與,用于將n的最高位取出,因?yàn)槿〕龊笕绻麨?,那么結(jié)果就是0,如果為1,結(jié)果就是一個(gè)正整數(shù),所以這里加了一個(gè)問號(hào)表達(dá)式,來將結(jié)果變?yōu)?和1。后面的就很明了了。
3、復(fù)習(xí)一下運(yùn)算符的優(yōu)先級(jí)。按位與&是9級(jí),移位是6級(jí),問號(hào)表達(dá)式是14級(jí),所以計(jì)算順序是:移位>>按位與>>問號(hào)表達(dá)式。正好符合要求,所以一個(gè)括號(hào)也不用。
總結(jié)
以上是生活随笔為你收集整理的c语言打印一个整数的二进制形式的全部?jī)?nèi)容,希望文章能夠幫你解決所遇到的問題。
- 上一篇: margin-塌陷
- 下一篇: QPS相关的概念收集(吞吐量(TPS)、