C++初阶作业 Stackqueue 作业题一
创始人
2024-04-23 02:59:38
0

作者:@小萌新
专栏:@C++初阶
作者简介:大二学生 希望能和大家一起进步!
本篇博客简介:实现几道Stack和queue的作业题
在这里插入图片描述

Stack queue作业题

    • 最小栈问题
    • 栈的压入弹出序列
    • 逆波兰表达式问题
  • 总结

最小栈问题

它问题的题目描述是这样子的
在这里插入图片描述

什么意思呢? 用一句话解释下 就是设计一个栈

这个栈除了能够执行正常的操作之外我们还要可以随时的获取这个栈中的最小元素

那我们想想看我们的思路是什么?

是不是只要设计两个栈就好了?

一个栈正常的存放数据

一个栈比较下当前存放的数据是否比自己最小的数据小

如果小于自己最小的数据那就入这个数据 如果不小于自己最小的数据 那么就再入一次目前来说最小的数据

这道题的主要难点在于思路 思路解决了 后面的问题也就解决了

代码表示如下

class MinStack {
public:MinStack() {}void push(int val) {_stk.push(val);if (_stkmin.empty()){_stkmin.push(val);}else{if (_stkmin.top() > val){_stkmin.push(val);}else{_stkmin.push(_stkmin.top());}}}void pop() {_stk.pop();_stkmin.pop();}int top() {return _stk.top();}int getMin() {return _stkmin.top();}private:stack _stk;stack _stkmin;
};

在这里插入图片描述

栈的压入弹出序列

题目如下

在这里插入图片描述
这里的题目要求我们来设计一个算法 检验栈的插入弹出序列是否是有效的

也就是说 最后能否完全弹出所有的数据

那想想看 我们这个时候应该怎么做呢?

要设计一个算法去计算有点太难了是不是

那么我们可不可以直接使用一个栈来模拟这个过程呢?

如果模拟通过是不是就表示肯定能通过了啊

我们一开始可以设计两个指针

一个指针指向插入数据的数组

一个指针指向删除数据的数组

像这样

在这里插入图片描述

当我们的出栈序列不等于入栈序列的时候那就一直入栈

当我们的出栈序列等于入栈序列的时候呢 就开始出栈

原则是:出掉所有符合出栈序列的数

在这里插入图片描述
像是这种情况 就代表出掉了所有的可以出的序列了

所以我们这个时候就停止出栈

当5也入栈的时候

在这里插入图片描述
这个时候就是按照 5 3 2 1的顺序出栈了

那么我们的代码表示如下

class Solution {
public:bool IsPopOrder(vector pushV,vector popV) {stack st;int pushvi = 0;int popvi = 0;while(pushvi < pushV.size()){st.push(pushV[pushvi]);pushvi++;// 判断是否要删除while(!st.empty() && st.top() == popV[popvi]){st.pop();popvi++;}}// 最后判断下结束return popvi == popV.size(); }
};

运行结果如下

在这里插入图片描述

逆波兰表达式问题

题目如下

在这里插入图片描述

这里大家首先要理解逆波兰表达式究竟是什么?

大家可以上各类视频网站详细了解下 由于博客篇幅限制 这里

就只谈逆波兰表达式如何使用

它的原则其实很简单就只有两条

1 如果我们遍历到加减乘除四个字符串 那么我们就从栈中取出两个元素来分别作为左操作数和右边操作进行运算 之后还将它入栈

2 如果我们遍历到了数字字符串 那么我们就将它转化成整型数字 然后存放到栈当中去

那么对应的代码表示也就很简单了

long num1 = st.top(); st.pop();long num2 = st.top(); st.pop();if (x == "+") st.push(num2 + num1);if (x == "-") st.push(num2 - num1);if (x == "*") st.push(num2 * num1);if (x == "/") st.push(num2 / num1);
          st.push(stol(x));

最后在栈里面的数字其实就是我们要求的答案了

那么完整的代码表示如下

class Solution {
public:int evalRPN(vector& tokens) {stack st;for (auto x : tokens){if (x == "+" || x =="-" || x =="*" || x =="/"){long num1 = st.top(); st.pop();long num2 = st.top(); st.pop();if (x == "+") st.push(num2 + num1);if (x == "-") st.push(num2 - num1);if (x == "*") st.push(num2 * num1);if (x == "/") st.push(num2 / num1);}else{st.push(stol(x));}}return st.top();}
};

运行结果如下

在这里插入图片描述

总结

在这里插入图片描述
讲解了栈的三道题目 最小栈问题 栈的压入弹出序列 逆波兰表达式问题

相关内容

热门资讯

保存时出现了1个错误,导致这篇... 当保存文章时出现错误时,可以通过以下步骤解决问题:查看错误信息:查看错误提示信息可以帮助我们了解具体...
汇川伺服电机位置控制模式参数配... 1. 基本控制参数设置 1)设置位置控制模式   2)绝对值位置线性模...
不能访问光猫的的管理页面 光猫是现代家庭宽带网络的重要组成部分,它可以提供高速稳定的网络连接。但是,有时候我们会遇到不能访问光...
表格中数据未显示 当表格中的数据未显示时,可能是由于以下几个原因导致的:HTML代码问题:检查表格的HTML代码是否正...
本地主机上的图像未显示 问题描述:在本地主机上显示图像时,图像未能正常显示。解决方法:以下是一些可能的解决方法,具体取决于问...
表格列调整大小出现问题 问题描述:表格列调整大小出现问题,无法正常调整列宽。解决方法:检查表格的布局方式是否正确。确保表格使...
不一致的条件格式 要解决不一致的条件格式问题,可以按照以下步骤进行:确定条件格式的规则:首先,需要明确条件格式的规则是...
Android|无法访问或保存... 这个问题可能是由于权限设置不正确导致的。您需要在应用程序清单文件中添加以下代码来请求适当的权限:此外...
【NI Multisim 14...   目录 序言 一、工具栏 🍊1.“标准”工具栏 🍊 2.视图工具...
银河麒麟V10SP1高级服务器... 银河麒麟高级服务器操作系统简介: 银河麒麟高级服务器操作系统V10是针对企业级关键业务...