C語言中的位操作例子(將任一整數轉換爲二進制形式)

將任一整數轉換爲二進制形式

*問題分析與算法設計
將十進制整數轉換爲二進制的方法很多,這裏介紹的實現方法利用了C語言能夠對位進行操作的特點。對於C語言來說,一個整數在計算機內就是以二進制的形式存儲的,所以沒有必要再將一個整數經過一系列的運算轉換爲二進制形式,只要將整數在內存中的二進制表示輸出即可。

#include<stdio.h>
void printb(int,int);
int main()
{
    int x;printf("Input number:");
    scanf("%d",&x);
    printf("number of decimal form:%d/n",x);
    printf(" it's binary form:");
    printb(x,sizeof(int)*8); /*x:要轉換的整數 sizeof(int):int型在內存中所佔的字節數 sizeof(int)*8:int型對應的位數*/
    putchar('/n');
    return 0;
}

void printb(int x,int n)
{
    if(n>0)
    {
        putchar('0'+((unsigned)(x&(1<<(n-1)))>>(n-1))); /*輸出第n位*/
        printb(x,n-1); /*遞歸調用,輸出x的後n-1位*/
    }
}

注意:
1、putchar 只能在屏幕上一次輸出1個字符;
2、位操作中注意,左移操作符(<<)從右邊開始用0補空位,右移操作符(>>)對於有符號數,從左邊插入符號爲的拷貝,對於無符號數,則是從左邊插入0,所以需要強制類型轉換爲unsigned。

本文來自CSDN博客,轉載請標明出處:http://blog.csdn.net/digu/archive/2007/08/04/1726570.aspx

發佈了30 篇原創文章 · 獲贊 21 · 訪問量 45萬+
發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章