stack/queue

链表完了之后就是我们的栈和队列了,当然我们的STL中也有实现,下面我们先来看一下简单用法,跟我们之前C语言实现的一样,stack和queue有这么几个重要的成员函数

最主要的就是这么几个:empty,push,pop,top(front),size,为什么要说这几个重要的呢?因为我们发现,stack和queue并没有我们之前的容器的迭代器,说明它们跟之前学的容器并不同,它们叫做适配器

什么叫做适配器呢?我们听过笔记本电脑的电源适配器,它就是将220V的电压转化成电脑需要的电压,所以适配器的本质是转换回到我们这里,stack和queue这个适配器就可以将其他的容器转换成实例化后的stack和queue

我们可以看到,类模板的第二个参数是要传一个容器,当然不传也行,它是有缺省值的,我们可以来试一下

既然如此,我们要模拟实现的话,就不用像之前那么写了,而是跟库一样,模板参数传个容器,下面的几个关键函数赋用容器的就可以了

template<class T,class container>
class stack {
public:void push(const T& x) {_con.push_back(x);}void pop() {_con.pop_back();}bool empty() {return _con.size() == 0;}const T& top() {return _con.back();}size_t size() {return _con.size();}
private:container _con;
};
template<class T, class container>
class queue {
public:void push(const T& x) {_con.push_back(x);}void pop() {_con.pop_front();}bool empty() {return _con.size() == 0;}const T& front() {return _con.front();}size_t size() {return _con.size();}
private:container _con;
};

下面来几道有关的题来帮助我们更好的使用

这个题其实就是模拟我们人脑在做这种题时的想法,我们一般先看弹出顺序的第一个,然后看怎么怎么压入才会让它第一个弹出。第一个其实跟后边几个都一样,最后走到头,看栈是否为空,为空就是符合

class Solution {public:bool IsPopOrder(vector<int>& pushV, vector<int>& popV) {stack<int>s;int n = popV.size();for (int pushi = 0, popi = 0; pushi < n && popi < n;) {while (s.empty() || s.top() != popV[popi]) {s.push(pushV[pushi++]);if (pushi == n)break;}while (!s.empty() && s.top() == popV[popi]) {s.pop();popi++;}}if (s.empty())return true;return false;}
};

这里实际上就是给你一个后缀表达式,让你求出表达式的值,我们人一般看的就是中缀表达式,那么后缀表达式是什么呢?其实就是把运算符放到两个操作数的后面。所以解题思路就是看到数字就入栈,看到运算符就从栈中取两个值进行运算,把结果再放到栈中,直到把后缀表达式走完

class Solution {
public:int evalRPN(vector<string>& t) {
stack<int>st;
for(auto e:t){if(e=="+"||e=="-"||e=="*"||e=="/"){int right=st.top();st.pop();int left=st.top();st.pop();
switch(e[0]){case '+':st.push(left+right);break;case '-':st.push(left-right);break;case '*':st.push(left*right);break;case '/':st.push(left/right);break;
}}else st.push(stoi(e));
}
return st.top();}
};

我们这里是给定一个后缀表达式,那么我们应该如何求一个中缀表达式的后缀表达式呢?我这里简单实现了一下,可以传一个string,string里面要么是字母用来表示数字,要么是+-*/

string postfix(string s) {stack<char>st;string ret;for (int i = 0; i < s.size();) {char e = s[i];if (e == '+' || e == '-' || e == '*' || e == '/') {if (st.empty()) {st.push(e);i++;}else if ((e == '*' || e == '/') && (st.top() == '+' || st.top() == '-')) {st.push(e);i++;}else {ret += st.top();st.pop();}}else if (e == '(') {int j = i;int k = j;int num = 1;for (k = j+1; k < s.size(); k++) {if (s[k] == '(')num++;if (s[k] == ')'&&num==1)break;if (s[k] == ')')num--;}string tmp(s.begin() + j + 1, s.begin() + k);ret += postfix(tmp);i+=k-j+1;}else {ret += e;i++;}}while (!st.empty()) {ret += st.top();st.pop();}return ret;
}

先简单说一下一个正常的式子转后缀表达式是什么逻辑,先说没有括号的情况下

给一个string,从左向右开始:先创建一个栈

1.如果遇到非运算符直接写入到最终结果中

2.如果遇到运算符,(1).如果栈为空或此运算符比栈顶运算符的优先级高,那么就入栈;(2).如果优先级相等或低,那么栈顶元素出栈,放到最终结果,继续仍然用此运算符进行下一轮判断

一直循环,直到string结束,最后把栈中的都移入到最终结果

如果有括号,将括起来的部分进行函数递归,重复上述过程,把递归完之后的结果加入到最终结果中

层序遍历肯定是要用到队列的,这个题的返回值告诉我们要一层一层的给到vector中,这就要求我们记录下每一层的节点个数才可以

class Solution {
public:vector<vector<int>> levelOrder(TreeNode* root) {vector<vector<int>> ret;if (root == nullptr)return ret;queue<TreeNode*> qu;qu.push(root);int levelsize = qu.size();while(!qu.empty()){vector<int>f;while(levelsize--){TreeNode* tmp=qu.front();qu.pop();f.push_back(tmp->val);if(tmp->left!=nullptr)qu.push(tmp->left);if(tmp->right!=nullptr)qu.push(tmp->right);}ret.push_back(f);levelsize=qu.size();}return ret;}
};

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/725187.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

Spring揭秘:ImportBeanDefinitionRegistrar应用场景及实现原理!

内容概念 ImportBeanDefinitionRegistrar接口提供了强大的动态注册Bean的能力&#xff0c;它允许开发者在Spring容器初始化时&#xff0c;灵活地根据特定条件或需求来添加或修改Bean定义&#xff0c;从而实现更为精细的控制和扩展性。这是构建可扩展框架、插件系统或处理复杂配…

2024.03.05作业

select实现tcp并发服务器 #include "test.h"#define SER_IP "192.168.42.106" #define SER_PORT 8888int create_socket() {int sfd socket(AF_INET, SOCK_STREAM, 0);if(sfd -1){perror("socket error");exit(-1);}printf("sfd %d\n&q…

安装VMWare+创建Linux虚拟机

点击VMware官网进入官网&#xff0c;下载VMware安装包。 一、安装VMware 一、安装VMware软件 &#xff08;1&#xff09;点击下一步 &#xff08;2&#xff09;勾选“我接受许可协议中的条款”&#xff0c;再点 ”击下一步“。 &#xff08;3&#xff09;选择下一步&#xf…

Linux编程3.2 进程-C程序启动过程

正常情况Linux 启动流程&#xff1a; ① BIOS 启动&#xff0c;完成自检&#xff0c;选择启动硬件 ②如果是磁盘系统读取 MBR ③从 MBR 指示&#xff0c;找到 GRUB 所在分区&#xff0c;加载 GRUB 显示菜单 ④加载 Linux 内核到内存中 ⑤执行 INIT 程序 ⑥进入用户界面 1、内核…

nvm安装、部署以及使用

1. nvm安装 官方地址&#xff1a;https://github.com/nvm-sh/nvm/blob/master/README.md nvm window安装&#xff1a;https://github.com/coreybutler/nvm-windows/releases 看个人习惯&#xff0c;通过不同形式来安装nvm&#xff0c;省劲就用.exe安装即可。 Tips&#xff1…

「连载」边缘计算(二十五)03-05:边缘部分源码(源码分析篇)

&#xff08;接上篇&#xff09; 1&#xff09;EdgehubConfig初始化具体如下所示。 config.InitEdgehubConfig() config.InitEdgehubConfig()函数定义具体如下所示。 KubeEdge/edge/pkg/edgehub/config/config.go // InitEdgehubConfig init edgehub config func InitEdgeh…

代码随想录算法训练营第三十四天|LeetCode860 柠檬水找零、LeetCode406 根据身高重建队列、LeetCode452 用最少数量的箭引爆气球

860.柠檬水找零 思路&#xff1a;只有5、10、20三种面额的纸币&#xff0c;因此每接收一种纸币对应的数量就&#xff0c;当接收10的&#xff0c;5的数量就--&#xff0c;当接收20的&#xff0c;有限消耗10的纸币&#xff08;贪心&#xff09;&#xff0c;因为10只能用于20找零…

【Flink网络数据传输(4)】RecordWriter(下)封装数据并发送到网络的过程

文章目录 一. RecordWriter封装数据并发送到网络1. 数据发送到网络的具体流程2. 源码层面2.1. Serializer的实现逻辑a. SpanningRecordSerializer的实现b. SpanningRecordSerializer中如何对数据元素进行序列化 2.2. 将ByteBuffer中间数据写入BufferBuilder 二. BufferBuilder申…

FreeRtos自学笔记3-----参考正点原子视频

FreeRtos任务的创建与删除 任务的创建与删除本质上是调用FreeRtos的API函数。 API函数&#xff1a; 1.xTaskGreate():动态创建任务函数&#xff1b; 2.xTaskGreateStatic();静态创建任务函数&#xff1b; 3.xTaskDelete():任务删除 动态创建任务&#xff1a;任务的任务控制块以…

java 中 string常用方法及相关的例子

我将为您详细讲解 Java 中 String 类的常用方法及其相关例子。String 类是 Java 中最常用的类之一&#xff0c;它代表字符串&#xff0c;提供了许多用于操作字符串的方法。 1. 字符串比较 - equals(Object obj): 比较字符串的内容是否相等。 - equalsIgnoreCase(String str): 比…

自研cloud框架专题

自己开发的cloud框架,可作为企业java web开发底层依赖,提供多个模块能力,降低搭建环境难度,增强模块能力. 开源地址:https://github.com/2892824942/ty-cloud 自研cloud框架专题–框架介绍&#xff08;零&#xff09; 自研cloud框架专题–mybatis-puls模块&#xff08;一&…

Linux 如何安装python

【我的系统是Centos7】在 linux上安装Python之前需要先安装前置依赖程序. 登录Linux中,使用 yum程序进行依赖程序安装,执行如下命令: yum install wget bzip2-devel openssl-devel ncurses-devel sqlite-devel readline-devel tk-devel gcc make zlib zlib-devel libffi-dev…

如何利用python实现自己的modbus-tcp库

如果你想使用纯Socket编程来实现Modbus TCP通讯,而不是依赖于Modbus库,你需要理解Modbus TCP协议的细节,并能够手动构建和解析Modbus消息。以下是一个简单的示例,展示了如何使用Python的socket库来实现Modbus TCP通讯: 了解Modbus TCP协议: Modbus TCP协议使用TCP作为底层…

code: 500 ] This subject is anonymous - it does not have any identifying

项目场景&#xff1a; 相关背景&#xff1a; 使用idea 开发java 项目&#xff0c;前端页面请求 页面中相关的接口时&#xff0c;idea 控制台有报错信息出现&#xff0c;前端请求失败。 问题描述 问题&#xff1a; 使用idea 开发java 项目&#xff0c;前端页面请求 页面中相…

Java学习笔记004——接口概念理解及意义

一个类中有抽象方法&#xff0c;则必须声明为abstract&#xff08;做为抽象类&#xff09;&#xff0c;抽象类不能实例化。子类继承抽象类&#xff0c;必须对所有的抽象方法重写&#xff0c;否则依然有抽象方法&#xff0c;还是抽象的&#xff0c;无法实例化。故抽象类常做为基…

【three.js】22. Imported Models导入模型

22. Imported Models导入模型 介绍 Three.js 可以让你创建很多原始几何体&#xff0c;但是当涉及到更复杂的形状时&#xff0c;我们最好使用专用的 3D 软件建模。 在本课中&#xff0c;我们将使用已经制作好的模型&#xff0c;但我们将在以后的课程中学习如何完全在 3D 软件中…

计划任务与SSH远程登录

一、计划任务 一次性调度执行——at yum -y install at #安装at systemctl status atd # 查看启动状态 systemctl start atd # 启动服务 systemctl enable atd # 设置开机启动 at now 5min #5分钟后开始执行 at> 要执行的内容 at > <E…

整合shoir

​ 目录 一、📢前言 二、📝SpringBoot整合Shiro 2.1 📲导入依赖 org.springframework.boot spring-boot-starter-web <dependency><groupId>org.springframework.boot</groupId><artifactId>spring-boot-devtools</artifactId><s…

【详识C语言】自定义类型之二:枚举

本章重点 枚举 枚举类型的定义 枚举的优点 枚举的使用 枚举 枚举顾名思义就是一一列举。 把可能的取值一一列举。 比如我们现实生活中&#xff1a; 一周的星期一到星期日是有限的7天&#xff0c;可以一一列举。 性别有&#xff1a;男、女、保密&#xff0c;也可以一一列举。…

vscode c/c++ 检测到 #include 错误。请更新 includePath。

问题背景 使用vscode打开项目后&#xff0c;头文件显示红色波浪线&#xff0c;没有引入。 检测到 #include 错误。请更新 includePath。已为此翻译单元(xxx)禁用波形曲线。 解决方法 gcc -v -E -x c - 显示所有头文件路径。 打开c_cpp_properties.json文件&#xff0c;粘贴…