两个栈实现一个队列

两个栈实现一个队列

 - 栈 : 先进后出
 - 队列:先进先出
  实现方法:一个栈实现队列的进,一个栈实现队列的出
  • 栈的操作方法:
typedef struct stack
{
	int *data;
	int top;
}stack;

void InitStack(stack *st)
{
	if(st==NULL) exit(0);
	st->data=(int *)malloc(sizeof(int)*INITSIZE);
	st->top=0;
}

int FullStack(stack *st)
{
	if(st==NULL) exit(0);
	if(st->top==INITSIZE) 
	{
		return 1;
	}
	return 0;
} 
int EmptyStack(stack *st)
{
	if(st==NULL) exit(0);
	if(st->top==0) 
	{
		return 1;
	}
	return 0;
}
int PushStack(stack *st,int value)
{
	if(st==NULL) exit(0);
	if(!FullStack(st))
	{
		st->data[st->top++]=value; 
		return 1;
	}
	return 0;
}

int PopStack(stack *st)
{
	if(st==NULL) exit(0);
	if(!EmptyStack(st))
	{
		st->top--;
		return 1;
	}
	return 0;
}
int TopStack(stack *st,int *val)
{
	if(st==NULL) exit(0);
	{
		*val=st->data[st->top-1];	
		return 1;
	}
	return 0;
}

int Destroy(stack *st)
{
	if (st==NULL) exit(0);
	free(st->data);
	st->data=NULL;
	st->top=0;
	return 1;
}

  • 队列的操作方法:
typedef struct queue
{
	 stack stin;
	 stack stout;
}queue;
void InitQueue(queue *que)
{
	if(que==NULL) exit(0);
	InitStack(&que->stin);
	InitStack(&que->stout);
}
int PushQueue(queue *stq,int q)
{
	if(stq==NULL) exit(0);
	// 判断满  stin满  stout非空  无法倒数据
	if(FullStack(&stq->stin)&&!EmptyStack(&stq->stout))
	{	
		return 0;
	}
		int tmp=0;
		while(!EmptyStack(&stq->stin))  //当stin不为空
		{   
			TopStack(&stq->stin,&tmp);
			PushStack(&stq->stout,tmp);
			PopStack(&stq->stin);
		}
		PushStack(&stq->stout,q);
		return 1;
}
int PopQueue(queue *stq)
{
	if(stq==NULL) exit(0);
	//判断空  
	if(EmptyStack(&stq->stin)&&EmptyStack(&stq->stout))
	{
		return 0;
	}
	int tmp=0;
	while(!EmptyStack(&stq->stin))
	{
		TopStack(&stq->stin,&tmp);
		PushStack(&stq->stout,tmp);
		PopStack(&stq->stin);
	}
	PopStack(&stq->stout);
	return 1;
}
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值