概述
实验课题一: 将一个十进制数转换成另外一个P进制数字符串(可以是二进制到十六进制)。转换函数的原
型为:
void Convert (int n, char str[], unsigned P);
n:输入,待转换的数
str:输出,转换好的P进制字符串
P:输入,要转换的进制,取值可从2到16。如果在这范围之外,可认为输入错,不做转换。
将一个整数转换成P进制的数,我们可以采用如下的方法:
例:十进制转换成八进制(P等于8):(66)10=(102)8
66/8=8 余 2
8/8 =1 余 0
1/8 =0 余 1
当商为0时转换结束,转换结果为上述过程余数序列的逆序:102。
先求得的余数在写出结果时最后写出,最后求出的余数最先写出,符合栈的LIFO性质,故可用栈来实现数
制转换。
#include
#include
#define maxsize 100
typedef struct
{
char data[maxsize];
int top;
}sqstack,*Stack;
Stack initstack()
{
Stack s;
s=(Stack)malloc(sizeof(sqstack));
s->top=-1;
return s;
}
int push(Stack s,char ch)
{
if(s->top>=maxsize)
return 0;
else
{
s->data[++s->top]=ch;
return 1;
}
}
int pop(Stack s,char *ch)
{
if(s->top==-1)
return 0;
else
{
*ch=s->data[s->top--];
return 1;
}
}
void Convert (int n, char str[], unsigned p)//十进制数据n向p进制转换
{
Stack s;
int i=0;
s=initstack();
while(n)
{
if(n%p<10)
push(s,n%p+'0');
else
push(s,n%p+'A'-10);
n=n/p;
}
while(s->top!=-1)
pop(s,&str[i++]);
str[i]='