C語言day07-15進制查表法

pragma mark 進制查表法

pragma mark 概念

pragma mark 代碼

#include <stdio.h>
void printfBinary(int value);
void printfBunary2(int value);
void printOct(int value);   // 8進制
void printHex(int value);   //  16進制

void printHex2(int value);  // 16進制
  void printOct2(int value);// 8進制
void printfBunary3(int value); // 2進制
int main()
{
    /*
     0000 0000 0000 0000 0000 0000 0000 1010
     0000 0000 0000 0000 0000 0000 0000 0001
     */
    int num = 10;   // 1010
//    printfBunary2(num);
//    printOct(num);
//    printHex(num);
//    printHex2(num);
//    printOct2(num);
    printfBunary3(num);

    return 0;
}
void printfBunary3(int value)
{
    // 1.定義一個數(shù)組,用于保存二進制中所有的取值
    char charValues[] = {'0','1'};
    // 2.定義一個數(shù)組,用于保存查詢后的結(jié)果
    char results [32] = {'0'};
    // 3.定義一個變量,用于記錄當前需要存儲到查詢結(jié)果數(shù)組的索引
    int pos = 32;
    
    while (value != 0) {
        // 1.取出1位的值
        int res = value & 1;
        // 2.利用取出來值到表中查詢對應(yīng)的結(jié)果
        char c = charValues[res];
        // 3.存儲查詢結(jié)果
        results[--pos] = c;
        // 4.移除二進制被取過的1位
        value = value >> 1;
    }
    // 4.打印結(jié)果
    for (int i = pos; i < 32; i ++) {
        printf("%c",results[i]);
    }
    printf("\n");
}
void printOct2(int value)
{
    // 1.定義一個數(shù)組,用于保存八進制中所有的取值
    char charValues[] = {'0','1','2','3','4','5','6','7'};
    // 2.定義一個數(shù)組,用于保存查詢后的結(jié)果
    char results [11] = {'0'};
    // 3.定義一個變量,用于記錄當前需要存儲到查詢結(jié)果數(shù)組的索引
    int pos = 11;
    while (value != 0) {
        // 1.取出3位的值
        int res = value & 7;
        // 2.利用取出來得值到表中查詢對應(yīng)的結(jié)果
        char c = charValues[res];
        // 3. 存儲查詢的結(jié)果
        results [--pos] = c;
        // 4.移除二進制被取過的三位
        value = value >> 3;
    }
    // 4.打印結(jié)果
    for (int i = pos; i < 11; i ++) {
        printf("%c",results[i]);
    }
    printf("\n");
}
void printHex2(int value)
{
    // 1.定義一個數(shù)組,用于保存十六進制中所有的取值
    // 規(guī)律:取出的4個二進制位得到的值,正好是數(shù)組中角標對應(yīng)的值
    char charValue[] = {'0','1','2','3','4','5','6','7','8',
        '9','a','b','c','d','e','f'};   // 表 裝了是可能所有的取值
    char results[8] = {'0'};
    int pos = 8;
    while (value != 0) {
        // 取出4位的值
        int res = value & 15;
        // 利用這個值作為索引去數(shù)組中查詢對應(yīng)的十六進制的值
        char  c = charValue[res];
//        printf("%c",c);
        // 將取出來的值防盜結(jié)果數(shù)組中
        results [--pos] = c;
//        results[] = c;
        // 每取完一次,就干掉它最低的4位
        value = value >> 4;
//        printf("pos = %i",pos);
    }
    for (int i = pos; i < 8; i ++) {
        printf("%c",results[i]);
    }
    printf("\n");
}

void printHex(int value)
{
    for (int i = 0; i <= 8; i++) {
        int res = value & 15;   // 1111
        // 對十六進制進行特殊處理
        if (res > 9) {
            char c = res - 10 + 'a';
            printf("%c",c);
        }
        else
        {
            printf("%i",res);
        }
        value = value >> 4;
    }
}
void printOct(int value)
{
    for (int i = 0; i < 11; i++) {
        int res = value & 7;    // 111
        printf("%i",res);
        value = value >> 3;
    }
}
void printfBunary2(int value)
{
    for (int i = 0; i<=32; i++)
    {
        int res = value & 1;
        printf("%i",res);
        value = value >> 1;
    }
    printf("\n");
}
void printfBinary(int value)
{
//    int offset = sizeof(value) * 8 - 1;
    // 乘以 2的3次冪
    int offset = (sizeof(value) << 3) - 1;
//    int offset = 31;
    while (offset >=0) {
        int res = (value >>offset) & 1;   // 右移 與1
        printf("%i",res);
        offset --;
    }
    printf("\n");
}


最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
平臺聲明:文章內(nèi)容(如有圖片或視頻亦包括在內(nèi))由作者上傳并發(fā)布,文章內(nèi)容僅代表作者本人觀點,簡書系信息發(fā)布平臺,僅提供信息存儲服務(wù)。

推薦閱讀更多精彩內(nèi)容