IT数码 购物 网址 头条 软件 日历 阅读 图书馆
TxT小说阅读器
↓语音阅读,小说下载,古典文学↓
图片批量下载器
↓批量下载图片,美女图库↓
图片自动播放器
↓图片自动播放器↓
一键清除垃圾
↓轻轻一点,清除系统垃圾↓
开发: C++知识库 Java知识库 JavaScript Python PHP知识库 人工智能 区块链 大数据 移动开发 嵌入式 开发工具 数据结构与算法 开发测试 游戏开发 网络协议 系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程
数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁
 
   -> 数据结构与算法 -> 预备役的那些事--栈与队列 -> 正文阅读

[数据结构与算法]预备役的那些事--栈与队列

? ? ? ? 对于栈和队列,想必大家都很熟悉吧!

? ? ? ? 今天我来分享一道栈和队列结合在一起的题目。

? ? ? ? 题目如下:

????????

冰冰子最近新学习了队列和栈两种重要的数据结构,他知道它们具有push 和pop操作。

而冰冰子现在想同时研究栈和队列,于是,他开始了一个实验。

现在,假设队列和栈都是空的。给定一系列push k和pop操作之后,冰冰子想知道队列和栈中分别存的数字。若队列或栈已经空了,仍然接收到pop操作,则输出error。

Input

第一行为m,表示有m组测试输入,m<100。
每组第一行为n,表示下列有n行push k或pop操作。(n<150)
接下来n行,每行是push k或者pop,其中k是一个整数。
(输入保证同时在队列或栈中的数不会超过100个)

Output

对每组测试数据输出两行,第一行是队列情况,若在队列空时收到pop操作,则输出error。其余情况将队列按照对头至队尾顺序输出队列中所有元素,中间用空格隔开。第二行是栈的情况,若在栈空时收到pop操作,则输出error。其余情况下按照栈底至栈顶的顺序输出栈中所有元素。

Sample Input

2
4
push 1
push 3
pop
push 5
1
pop

Sample Output

3 5
1 5
error
error

? ? ? ? 说实话呀,刚接触栈和队列的我,看到这个题目时,有点懵逼:应该很麻烦吧。但其实这只是题目的外表难,它的精髓并不难。一起来看看吧。

#include<iostream>

using namespace std;

const int maxn = 101;

int Q[maxn]; //定义一个栈?
int top; ?//栈顶?

void pushq(int x) {
?? ?Q[top++]=x;
}

int popq() {
?? ?return Q[--top];
}

int E[maxn]; //定义一个队列
int front,back; ?//队列头 ?和 ? 尾巴

void pushe(int x) {
?? ?E[back++]=x;
}?

int pope() {
?? ?return E[front++];
}

int main()
{
? ? int a;
? ? int m;
? ? cin >> m;
? ? while (m --) ? ?//多组输入
? ? {
? ? ?? ?int y = 0; ? //这只是起到一个标记的作用
? ? ?? ?int w = 0;
? ? ?? ?Q[101] = {0};
? ? ?? ?E[101] = {0};
? ? ?? ?back = 0;
? ? ?? ?front = 0;
? ? ?? ?top = 0;
? ? ? ? string s;
? ? ? ? int n;
? ? ? ? cin >> n;
? ? ? ? for (int i = 0;i < n;i ++) ? ? ?
? ? ? ? {
? ? ? ? ? ? cin >> s;
? ? ? ? ? ? if(s == "push") ? ? ? ?//开始判断需要执行的命令
? ? ? ? ? ? {
? ? ? ? ? ? ? ? cin >> a; ? ? ? ? ? ?
? ? ? ? ? ? ? ? pushq(a); ? ? ? ? ?//栈和队列都要执行
? ? ? ? ? ? ? ? pushe(a);
? ? ? ? ? ? }
? ? ? ? ? ? else if (s == "pop")
? ? ? ? ? ? {
? ? ? ? ? ? ?? ?if(front >= back) ? //if队列为空
? ? ? ? ? ? ? ? {
? ? ? ? ? ? ? ? ? ? w = 1; ? ? ? ?//标记
? ? ? ? ? ? ? ? }
? ? ? ? ? ? ? ? else
? ? ? ? ? ? ? ? {
? ? ? ? ? ? ? ? ? ? pope();
? ? ? ? ? ? ? ? }
? ? ? ? ? ? ? ? if(top == 0) ? ? ?//if栈为空
? ? ? ? ? ? ? ? {
? ? ? ? ? ? ? ? ? ? w = 1; ? ? ? ? ?//标记
? ? ? ? ? ? ? ? }
? ? ? ? ? ? ? ? else
? ? ? ? ? ? ? ? {
? ? ? ? ? ? ? ? ? ? popq();
? ? ? ? ? ? ? ? }
? ? ? ? ? ? ? ??
? ? ? ? ? ? }
? ? ? ? }
? ? ? ??
? ? ? ? if (w == 1) ? ? ? ?//为空时 ? 栈和队列 都要 输出 ?eroor
? ? ? ? {
?? ??? ??? ?cout << "error" << endl << "error";
?? ??? ?}
? ? ? ??
?? ??? ??? ?
?? ??? ??? ?if (w == 0){
? ? ? ? ? ? while(front < back) ? ? ?//队列非空则输出
? ? ? ? ? ? {
? ? ? ? ? ? ? ? cout << pope() << " ";
? ? ? ? ? ? ? ? y = 1;
? ? ? ? ? ? }
// ? ? ? ? ? ?cout << pope();
?? ??? ??? ?}
? ? ? ? ? ? if (y == 1) ? ? ?//这里需要注意格式
? ? ? ? ? ? {
? ? ? ? ? ? cout << endl;
? ? ? ? ? ? }

?? ??? ??? ?if (w == 0) ? ?//如果栈不为空
?? ??? ??? ?{
?? ??? ??? ?for (int i = 0;i < top - 1;i ++)
?? ??? ??? ?{
?? ??? ??? ??? ?cout << Q[i] << " "; ? ? //输出值
?? ??? ??? ?}
?? ??? ??? ?cout << Q[top - 1];
?? ??? ??? ?}
? ? ? ? ? ? cout << endl; ? ? ? ? //这里注意 ? 格式 ? ?要求 ? 换行
? ? }
? ? return 0;
}

? ? ? ? 看来之后是不是很简单,只是有点长而已。其实可以简单一点,这就需要你来助我一臂之力。

  数据结构与算法 最新文章
【力扣106】 从中序与后续遍历序列构造二叉
leetcode 322 零钱兑换
哈希的应用:海量数据处理
动态规划|最短Hamilton路径
华为机试_HJ41 称砝码【中等】【menset】【
【C与数据结构】——寒假提高每日练习Day1
基础算法——堆排序
2023王道数据结构线性表--单链表课后习题部
LeetCode 之 反转链表的一部分
【题解】lintcode必刷50题<有效的括号序列
上一篇文章      下一篇文章      查看所有文章
加:2021-12-16 17:56:08  更:2021-12-16 17:58:34 
 
开发: C++知识库 Java知识库 JavaScript Python PHP知识库 人工智能 区块链 大数据 移动开发 嵌入式 开发工具 数据结构与算法 开发测试 游戏开发 网络协议 系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程
数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁

360图书馆 购物 三丰科技 阅读网 日历 万年历 2025年1日历 -2025/1/10 11:30:06-

图片自动播放器
↓图片自动播放器↓
TxT小说阅读器
↓语音阅读,小说下载,古典文学↓
一键清除垃圾
↓轻轻一点,清除系统垃圾↓
图片批量下载器
↓批量下载图片,美女图库↓
  网站联系: qq:121756557 email:121756557@qq.com  IT数码