当前位置:网站首页>Stack queue OJ question sharing and explanation
Stack queue OJ question sharing and explanation
2022-08-08 07:03:00 【@Love programming Xiaojie】
Beginning from today at the back of theOJ题,I agree withC++To take you realize,This need you to know firstC++STL里面的容器,As well as the related interface.
1、有效的括号
This is a typical stack is used to implement the questions,Give us a strings,Let's go to judge whether the inside of the parentheses matching one by one.
解题思路:
class Solution {
public:
bool isValid(string s) {
stack<char> st;
for(int i=0;i<s.size();i++)
{
if(s[i]=='['||s[i]=='{'||s[i]=='(')
{
st.push(s[i]);
}
else if(!st.empty()&&(s[i]==']'&&st.top()=='['
||s[i]=='}'&&st.top()=='{'
||s[i]==')'&&st.top()=='('))
{
st.pop();
}
else
{
return false;
}
}
return st.empty();
}
};
First of all, we create a stackst,Of course you can also use an array to simulate a stack,去遍历这个字符串,If there are any left parenthesis will stack,Otherwise if it is right parenthesis,We need and on the top of the stack elements to compare the match,就是s[i]和st.top(),Here of course there is also a need to pay attention to the problem,When comparing the stack is not empty,So it must add a judge,Determine the stack can't be empty,也就是!st.empty(),如果两个条件都不满足,That means and right parenthesis is not matching,直接返回false,Finally come out of time also need to determine whether the stack is empty,Because is empty it must be all matching braces,Because the number to avoid left parenthesis is greater than the right parenthesis,Out of the stack is empty,Means that the string is invalid,Of course, we only need to returnst.empty()即可,When is null will return true,反之返回假.
运行结果如下:
2、用栈实现队列
This is to give us a few of the queue interface,Let us use two stack to achieve queue,And let a few interfaces reach the requirement of the queue.
解题思路:
We can make a stack to into data,一个栈用来出数据,This way I draw a diagram to understand the.
入队列:
出队列:
如上图有,st1和st2两个栈,我们让st1来入数据,The data we just need tost2On the top of the stack elements topop即可.
class MyQueue {
public:
MyQueue() {
}
void push(int x) {
st1.push(x);
}
int pop() {
int top=0;
if(st2.empty())
{
while(!st1.empty())
{
st2.push(st1.top());
st1.pop();
}
top=st2.top();
}
else
{
top=st2.top();
}
st2.pop();
return top;
}
int peek() {
int top=0;
if(st2.empty())
{
while(!st1.empty())
{
st2.push(st1.top());
st1.pop();
}
top=st2.top();
}
else
{
top=st2.top();
}
return top;
}
bool empty() {
return st1.empty()&&st2.empty();
}
stack<int> st1;
stack<int> st2;
};
Here I am in class defines two stackst1和st2,第一个接口MyQueue()我们不需要实现,Because this is the constructor of this class,But we'll have to call stack directly constructor initializes,So we don't need to implement.
The second interface ispush,Also is to queue into data,Here we only need to adjust thest1Into the stack interfacest1.push(x)将xValues stored in the stack.
第三个接口popIs to make us the data,But the rules here back up data,According to we just thinkingst1The inside of the data importst2里面,但这里有一个需要注意的点,当st2不为空的时候,Data are still not out of the,So we don't need to be into data tost2,Otherwise the data error when data,我们只需要先将st2The stack data stored,And then will return to can stack data delete.
The fourth interfaces and the third is the same,It is not need to delete the data and,这里我就不多说了.
The fifth interface is simple,Is to determine whether a queue is empty,We only need to determine both the stack is empty,因为st1Don't empty instructions and data are not in the,st2Don't empty instructions and data do not finish the.
运行结果如下:
3、用队列实现栈
This topic and a topic on the contrary,用两个队列实现栈,Implementation of the stack four interfaces can be.
解题思路:
When we stack,Need the data into the into the queue isn't empty,Need out of the stack will not be for data import is empty empty queue queue inside,But leave it last,Is that we need to delete the data,Or drawing for everyone to understand:
入栈:
出栈:
如上图,Into the stack when all the data into the queue isn't emptyq1,The time we need toq1里面的前4A data importq2,最后q2In the rest of5Is that we need to delete the data.
class MyStack {
public:
MyStack() {
}
void push(int x) {
if(!_q1.empty())
{
_q1.push(x);
}
else
{
_q2.push(x);
}
}
int pop() {
queue<int>* emptyQ=&_q1;
queue<int>* nonemptyQ=&_q2;
if(!_q1.empty())
{
swap(emptyQ,nonemptyQ);
}
while(nonemptyQ->size()>1)
{
emptyQ->push(nonemptyQ->front());
nonemptyQ->pop();
}
int top=nonemptyQ->front();
nonemptyQ->pop();
return top;
}
int top() {
if(!_q1.empty())
{
return _q1.back();
}
else
{
return _q2.back();
}
}
bool empty() {
return _q1.empty()&&_q2.empty();
}
queue<int> _q1;
queue<int> _q2;
};
Here I am in class defines the first two queue_q1和_q2,The first function as well as the above because we'll have to call queue own constructor initializes,So what all don't need to write.
第二个pushIs to our into the stack and return stack elements,We only need to judge who is empty,Then turn it into data can be,At first, of course, all is empty,That is literally into a queue there.
第三个函数popIs to us out of the stack,Here I first defines twostak*类型的指针,Refer to the two stack,So I defaultq1为空,然后做一次判断,如果q1不为空,Is the exchange of two Pointers point to space,然后将指向q2Pointer to a pointq1The pointer into data,Then we save on the top of the stack elements,并将该数据删除,Finally return to save elementstop即可.
The fourth function is to we return to the top of the stack elements,We just need to get the last element isn't empty queue,So here and_q1为空就返回_q2.back(),反之返回_q1.back().
The fifth function whether the stack is empty,Both the stack is empty means there is no data to the,即为空.
运行结果如下:
4、设计循环队列
This topic we need to pay attention to the problem is,The cycle of the queue is,The space is fixed,Another topic also limits we can't useC++The built-in queue library,So we have two method to realize,Use an array or list,I like to use is an array.
解题思路:
我们可以用一个数组,The size of the first open fixed,And give two variables_front和_tail,For head and tail of the subscript
如图:
When no element insidefront和tailThe subscript is equal,But when there is datatailIs the last data of the next position of subscript.
When we want a queue is a need to change_front的下标的,另外当_tailIs equal to the number of array can store data,If at this time to insert,To check whether the array is full of,And have to change_tail的下标,所以我又加了一个_sizeThe number of effective data computing array.
如图:
如上面这种情况,The first data has been out of the,且tailHas come to the last data subscript next position,At this time we want to change the array subscript to0,To continue to insert,否则会越界.
class MyCircularQueue {
public:
MyCircularQueue(int k) {
v.resize(k);
_front=_tail=_size=0;
_k=k;
}
bool enQueue(int value)
{
if(_size==_k)
return false;
if(_tail==_k)
{
v[0]=value;
_tail=0;
}
else
{
v[_tail]=value;
}
_tail++;
_size++;
return true;
}
bool deQueue() {
if(_size==0)
return false;
if(_front==_k)
{
_front=1;
}
else
{
_front++;
}
_size--;
return true;
}
int Front() {
if(_size==0)
{
return -1;
}
if(_front==_k)
return v[0];
return v[_front];
}
int Rear() {
if(_size==0)
{
return -1;
}
return v[_tail-1];
}
bool isEmpty() {
return _size==0;
}
bool isFull() {
return _size==_k;
}
vector<int> v;
int _k;
int _size;
int _front;
int _tail;
};
I'll give you a an interface to analysis:
1、MyCircularQueue(int k),它给的kIs the size of the array need to open,我们需要将_size,_tail_front,At first all value of0,再将数组v开成k个数据的大小,将k赋值给_k,这个_k呢,是数组大小,At the back of the interface are applied to.
2、bool enQueue(int value),Is in the queue,插入成功返回真,反之返回假,We have to decide_size是否等于_k,If equal we will direct returnfalse,Then insert the data logic,如果_tail已经等于_kThat means we need to subscript as0这个位置插入value,把_tail置为0,Whereas only need in_tailThis position can be inserted,最后将_tail++和_size++,返回true.
3、bool deQueue(),Is to us out of the queue,即改变_front,进来先判断_size是否为0,如果为0No data can be a,直接返回false,There have two things need to decide
如果_front==_k,Above will be with us,The end of the array subscript a position+1其实就是0,而这时候_frontAlready in the final location of the next,所以这里将_front置为1,Otherwise, we just need to_front++即可,最后_size–一下,返回true.
4、int Front(),This is for us to team head data,The above requirements if the queue is empty return-1,So I'm here to judge the,In addition if here_front==_kWhen returning the subscript as0这个位置就行了.
5、int Rear()取队尾的数据,这里我们只需要返回_tail-1The location of the data line,Don't need to be special like the above judgment,因为_tailIt is the last of the array next position.
Behind the two interfaces, it is simple,Determine whether it is empty and determine whether full,Only need to decide_size是否等于0,判断_size是否等于_k即可.
运行结果如下:
That is all there is in this blog,如果觉得博主的文章还不错的话,请点赞+收藏️+留言支持一下博>主哦.
边栏推荐
猜你喜欢
MySQL高级
状态机控制移位寄存器multisim仿真过程中出现的状态变量和状态转移条件不匹配的问题
Makefile文件的编写(实例详解)
Mac下按装php的MongoDB扩展
RNN神经网络适用于什么,RNN神经网络基本原理
线性回归---Fit A Line
Dropout、剪枝、正则化有什么关系?什么是Dropout?
Variational Inference with Normalizing Flows
Rose essential oil market research: the current market output value exceeds 2.3 billion yuan, and the market demand gap is about 10%
Leetcode题目分享以及讲解
随机推荐
状态机控制移位寄存器multisim仿真过程中出现的状态变量和状态转移条件不匹配的问题
P23 传值和传引用
ps神经网络滤镜安装包,ai神经网络滤镜安装包
Unity HDRP下VRTK传送、穿墙 时画面淡入淡出、视觉遮挡无法正确显示问题解决
神经网络对数据的要求,神经网络分析相关性
MongoDB的备份与恢复
《Filter Pruning using Hierarchical Group Sparse》ICPR2020论文详解
Meta-Learning and in-context Learning
线性回归---Fit A Line
Accelerate CNNs from Three Dimensions: A Comprehensive Pruning Framework详解
文件常用操作 IO流原理及分类
Unity中获取一个物体下所有的子物体的方法
NVIDIA CUDA 高度并行处理器编程(八):并行模式:直方图计算
ESP32 温湿度和气体传感器驱动
P19 美颜相机的实现——基础铺垫1
人工神经网络的工作原理,神经网络的基本原理
关于Unity 按键事件响应错误触发UI事件的问题解决
RNN神经网络适用于什么,RNN神经网络基本原理
在ENSP中配置DHCP服务器
ResNet 原理与代码复现