顺序栈的十--八的进制数转换

数据结构课后,老师布置的第二次作业中进行进制数转换时,出现乱码的原因与解决
注意事项:对栈的各种操作名都是固定的,尽量别误用。
语句体要加花括号。
乱码原因可能是电脑问题
换电脑编译,问题解决。

#include<stdio.h>//数制转换 出现乱码
#define MAX 100
typedef struct{
	int data[MAX];
	int top;
}seqstack; 
//初始化
void initstack(seqstack l){
	l.top =-1;//赋值 可更改
}
//栈空
int emptystack(seqstack l){
	if(l.top==-1)//恒等于
	return 1;
	else
	return 0;
}
//栈满
int fullstack(seqstack l){
	if(l.top ==MAX-1)//恒等于
	return 1;
	else
	return 0;
}
//入栈
void push(seqstack &l,int x){//对栈的操作函数是固定的被乱改动
	if(fullstack(l))
	printf("full");
	else{//两语句,不加括号出错
	l.top ++;
	l.data [l.top ]=x;
	}
}
//出栈
void popstack(seqstack &l){
	if(emptystack(l)){
		printf("empty");
	}
	else{
	printf("%d ",l.data [l.top --]);
}
}
//八进制
void D_O(seqstack &l,int x){
	while(x){
		push(l,x%8);
		x=x/8;
	}
	while(!emptystack(l)){
		popstack(l);
	}
}
main()
{
	seqstack l;
	initstack(l);
	D_O(l ,57);
	return 0;
}

后两位数为乱码

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值