一厂镇、概念
二、代碼
#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);
}
// 轉(zhuǎn)換所有的進制
// value就是需要轉(zhuǎn)換的數(shù)值
// base就是需要&上的數(shù)
// offset 就是需要 右移的位數(shù)
void total(int value,int base,int offset)
{
// 1.定義一個數(shù)組,用于保存十六進制中所有的取值
char charValue[] = {'0','1','2','3','4','5','6','7','8','9','a','b','c','d','e','f'};
// 2.定義一個數(shù)組,用與保持查詢后的結(jié)果
char result[32] = {'0'};
// 3.定義一個變量,用于記錄當前需要存儲到查詢結(jié)果數(shù)組的索引
int pos = sizeof(result)/sizeof(result[0]);
while (value !=0) {
// 取出4位的值
int res = value & base; // 1 7 15
// 利用這個值 作為索引去數(shù)組中 查詢對應(yīng)的十六進制的值
char c = charValue[res];
// printf("%c",c);
// 將取出來的值 放到用于存儲結(jié)果的數(shù)組中
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");
}
最后編輯于 :
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者