方法二:
求余来算,比如求十进制数 x(x>100) 的8进制,先通过 x%8 可以得到个位(末位)上的数,当十进制数等于8时,必然会进位,求余的结果正好是不能进位的部分,x=x/8(这就像位移,x的8进制数向右移了一位),这样已经求出来的 个位 位移后没有了,原来的十位变成了个位,继续把得到的x按上面的方式求末位,就能求出来十位,按照这种方式得到的 8进制数 是反的(先得到个位,再十位。。。),这样很适合放到栈中,取得时候又会反过来,伪代码可以这样写:
while(x){
printf("%d",x%n);//会打印出x转换为 N进制数 从低位到高位上的每一位数
x/=n;
}
十进制转换N进制:
#include<stdio.h>
#include<stdlib.h>
#include<string.h>
typedef int INT;
typedef struct dd
{
INT data;
struct dd *next;
}LNode,*LStack;
LStack pushstack(LStack top,int x)
{
LStack p;
p=(LStack)malloc(sizeof(LNode));
if((x)!=-1) {p->data=(x); p->next=top; top=p;}
return top;
}
LStack outstack(LStack top,int *x)
{
LStack p=top;
*x=p->data;
top=p->next;
free(p);
return top;
}
main()
{
int x,n;
LStack top=NULL;
printf("请输入原数及要转换的进制:");
do{
scanf("%d%d",&x,&n); //输入一个十进制数和要转换的进制,比如3 2 得到1 }while(x>35||x<0||n<2);
while(x){ //这个循环把每一位放到栈中
top=pushstack(top,x%n);
x/=n;
while(top!=NULL)
{
top=outstack(top,&x);
if(x<10)
printf("%c",x+'0');
else
printf("%c",x+'A'-10);
}
return 0; }
unsigned buf[5];
sscanf(a,"%02x",&buf[2]);//这是10进制转换成16进制,结果在buf里。
同理,10进制转八进制只要把"%02x"换成8进制的就可以了
int main()
{
printf("输入一个十进制数:");
int num1,num2=0,i=0;
scanf("%d",&num1);
while(num1)
{
int temp = num1%8;
for(int j=0;j<i;j++)
temp *= 10;
num1 /= 8;
i++;
num2 += temp;
}
printf("转为八进制为:%d\n",num2);
return 0;
}
void conversion(){
initstack(S);
scanf(“%d“,N);
while(N){
push(S,N%8);
N=N/8;
}
while(!stackempty(S)){
pop(S,e);
printf(“%d”,e);
}
}
int main()
{
int a, b, c, d, e, f, h, i, j, k, l,m;
printf("请输入0到32767之间的值");
scanf_s("%d", &a);
b = a % 8;
c = a / 8;
e = c % 8;
f = c / 8;
h = f % 8;
i = f / 8;
j = i % 8;
k = i / 8;
l = k % 8;
printf("%1d%1d%1d%1d%1d\n", l, j, h, e, b);
}