任意进制数的转换
实例说明
将一个无符号整数转换为任意 d 进制数(2≤d≤16)。
实例解析
求 n 整除 d 的余数,就能得到 n 的 d 进制数的最低位数字,重复上述步骤,直至 n 为 0,依
次得到 n 的 d 进制数表示的最低位至最高位数字。由各位数字取出相应字符,就能得到 n 的 d 进
制的字符串。
主函数用于测试 trans 函数,要求输入一个待转换的正整数,接着调用 trans 函数进行转换,
并输出该正整数的 2~16 进制数转换结果。
程序代码
无符号整数的任意进制数转换
#include <stdio.h>
// system("cls");/* 清屏 */
void clrscr(){
system("cls");/* 清屏 */
}
#define M sizeof(unsigned int)*8
int trans(unsigned n, int d, char s[])
{
static char digits[] ="0123456789ABCDEF"; /* 十六进制数字的字符 */
char buf[M+1];
int j, i = M;
if(d<2||d>16)
{
s[0]='\0'; /* 不合理的进制,置 s 为空字符串 */
return 0; /* 不合理的进制,函数返回 0 */
}
buf[i]='\0';
do
{
buf[--i]=digits[n%d]; /*得出最低位,将对应字符存入对应数组中*/
n/=d;
}while(n);
/* 将工作数组中的字符串复制到 s */
for(j=0;(s[j]=buf[i])!='\0';j++,i++);
/* 其中控制条件可简写成 s[j]=buf[i] */
return j;
}
/* 主函数用于测试函数 trans() */
int main()
{
unsigned int num = 0;
int scale[]={2,3,4,5,6,7,8,9,10,11,12,13,14,15,16,1};
char str[33];
int i;
clrscr();
puts("Please input a number to translate:");
scanf("%d",&num);
printf("The number you input is %d.\nThe translation results are:\n",num);
for(i=0;i<sizeof(scale)/sizeof(scale[0]);i++)
{
if(trans(num,scale[i],str))
printf("%5d = %s(%d)\n",num,str,scale[i]);
else
printf("%5d => (%d) Error! \n",num,scale[i]);
}
printf("\n Press any key to quit...\n");
getch();
return 0;
}
程序运行结果
归纳注释
本实例将 0~F 等 16 个字符存储在静态字符数组里,通过该静态字符数组的引用来实现任意
进制数的转换。