利用栈和队列的基本运算将所构建的队列中的内容进行逆转(C语言实现)

将所构建的队列中的内容进行逆转

要求:编写一个算法,利用栈和队列的基本运算将所构建的队列中的内容进行逆转。
函数原型为void reverse(cqueue *q).
栈和队列基本运算包括判断队空isQueueEmpty()、出队outQqueue()、入队enQueue()、初始化栈initStack()、判断栈空isEmptyStack()、入栈push()、弹栈pop()等。

void reverse(queue q);//将队列中的内容逆转

void reverse(queue q){

    stack s = createStack();
    
    //将队列中的数据存入栈,再输入,就是队列的倒序
    while(!IsEmpty(q)){
        push(Front(q),s);
        DeQueue(q);
    }
    MakeEmpty(q);//将队列的头尾指针重置

    while(!isEmpty(s)){
        enter(topAndPop(s),q);//将栈中的数据重新放入队列中
    }
}

栈和队列的基本运算可以看我之前的文章队列的应用栈的应用

在这里插入图片描述

在这里插入图片描述

在这里插入图片描述
在这里插入图片描述
在这里插入图片描述
在这里插入图片描述

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值