美文网首页十天学会C语言
第07天C语言(16):进制查表法-优化

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

作者: liyuhong | 来源:发表于2017-07-10 09:34 被阅读17次
    一、概念
    二、代码
    #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");
    }
    

    相关文章

      网友评论

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

        本文链接:https://www.haomeiwen.com/subject/txlyhxtx.html