40行代码2个栈模拟一个队列

思路已经在代码中

#include <iostream>
#include<queue>
#include<stack>
using namespace std;
class Q {
private:
    stack<int> s1;
    stack<int> s2;
public :
    void push(const int& x) {
        s1.push(x);//添加元素时先把元素缓存在s1中
    }
    int front() {
        int x=0;//取出元素时,一般要先把s1中的元素全部倒入s2中,取元素是在s2中获取
        if (!s1.empty()) {//当你需要取出元素
            while (!s1.empty()) {//把s1栈中所有元素倒入s2中,利用栈的逆置元素的特性就能实现队列的作用
                x = s1.top();
                s1.pop();
                s2.push(x);
            }
            x = s2.top();
            return x;
        }
        else {
            if (!s2.empty()) {//如果s1栈已经空了,那么直接从s2中取出元素即可
                x = s2.top();
                return x;
            }
            else {
                throw exception("你不能对空队列取元素\n");
            }
        }
    }
    void pop() {
        if (!s2.empty()) {
            s2.pop();
        }
    }

};
int main()
{
    Q q;
    q.push(1);
    q.push(2);
    q.push(3);
    cout << q.front() << "  ";
    q.pop();
    cout << q.front() << "  ";
    q.pop();
    cout << q.front() << "  ";
    q.push(4);
    cout << q.front() << " ";
    q.pop();
    return 0;
}
  • 1
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论
可以使用两个栈模拟队列,具体实现如下: 1. 定义两个栈 Stack1 和 Stack2,用 Stack1 来存放入队的元素,用 Stack2 来处理出队操作。 2. 入队操作:将元素压入 Stack1。 3. 出队操作:首先判断 Stack2 是否为空,如果不为空,则弹出顶元素;如果为空,将 Stack1 中的元素依次出并压入 Stack2,再弹出顶元素。 下面是用 C 语言实现的代码: ```c #include <stdio.h> #include <stdlib.h> #define MAX_SIZE 100 // 定义结构体 typedef struct { int data[MAX_SIZE]; int top; } Stack; // 初始化 void initStack(Stack *s) { s->top = -1; } // 判断是否为空 int isStackEmpty(Stack *s) { return s->top == -1; } // 判断是否已满 int isStackFull(Stack *s) { return s->top == MAX_SIZE - 1; } // 入 void push(Stack *s, int value) { if (isStackFull(s)) { printf("Stack overflow!\n"); exit(1); } s->data[++s->top] = value; } // 出 int pop(Stack *s) { if (isStackEmpty(s)) { printf("Stack underflow!\n"); exit(1); } return s->data[s->top--]; } // 定义队列结构体 typedef struct { Stack s1; Stack s2; } Queue; // 初始化队列 void initQueue(Queue *q) { initStack(&q->s1); initStack(&q->s2); } // 入队 void enqueue(Queue *q, int value) { push(&q->s1, value); } // 出队 int dequeue(Queue *q) { int value; if (isStackEmpty(&q->s2)) { while (!isStackEmpty(&q->s1)) { value = pop(&q->s1); push(&q->s2, value); } if (isStackEmpty(&q->s2)) { printf("Queue underflow!\n"); exit(1); } } return pop(&q->s2); } int main() { Queue q; initQueue(&q); enqueue(&q, 10); enqueue(&q, 20); enqueue(&q, 30); printf("%d\n", dequeue(&q)); printf("%d\n", dequeue(&q)); printf("%d\n", dequeue(&q)); return 0; } ```

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

阿维的博客日记

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值