十天学会C语言

第07天C语言(16):进制查表法-优化

2017-07-10  本文已影响17人  liyuhong
一、概念
二、代码
#include <stdio.h>
void printfBinary(int num);
void printfOct(int num);
void total(int value,int base,int offset);
int main()
{
    printfBinary(10);
    printfOct(10);
    return 0;
}

void printfOct(int num)
{
    total(num, 7, 3);
}

void printfBinary(int num)
{
    total(num, 1, 1);
}

// 转换所有的进制
// value就是需要转换的数值
// base就是需要&上的数
// offset 就是需要 右移的位数
void total(int value,int base,int offset)
{
    // 1.定义一个数组,用于保存十六进制中所有的取值
    char charValue[] = {'0','1','2','3','4','5','6','7','8','9','a','b','c','d','e','f'};
    // 2.定义一个数组,用与保持查询后的结果
    char result[32] = {'0'};
    // 3.定义一个变量,用于记录当前需要存储到查询结果数组的索引
    int pos = sizeof(result)/sizeof(result[0]);

    
    while (value !=0) {
        // 取出4位的值
        int res = value & base; // 1 7 15
        // 利用这个值 作为索引去数组中 查询对应的十六进制的值
        char c = charValue[res];
        //        printf("%c",c);
        // 将取出来的值 放到用于存储结果的数组中
        result[--pos] = c;
        
        // 每取完一次 就干掉他最低的4位
        value = value >> offset;  // 1 3 4
//        printf("pos = %i\n",pos);
    }
    
    for (int i = pos; i < 32; i++) {
        printf("%c",result[i]);
    }
    printf("\n");
}
上一篇下一篇

猜你喜欢

热点阅读