每日一题~ (判断是否是合法的出栈序列)

大概的题意:

将 1-n 按照顺序进栈,问 输入的序列是否是合法的出栈序列。

遍历序列,如果当前这个值a小于 栈顶的值,说明它还未进栈(因为我们是按照顺序进栈的),所以我们将 一些元素进栈,知道a进栈。

经过这个操作之后,现在的栈,是a进来之后即以后的情况了。

所以 ,这个时候 如果栈顶元素是a,那么是合法的。

否则是非法的。

cpp 复制代码
#include <bits/stdc++.h>
using namespace std;
int n;
判断是否 是 合法的出栈顺序 
bool solve()
{
	vector<int>ve(n);
	for (int i=0;i<n;i++)
	cin>>ve[i];
	
	stack<int>st;
	st.push(1);int max=1;
	for(auto i:ve)
	{
		if (i>max){
			for (int j=max+1;j<=i;j++)
			st.push(j); 
			max=i;
		}
		if (st.top()!=i){
			return false;
		}
		else {
			st.pop();
		}
	}
	 return true;
}
int main()
{
	std::cin.tie(nullptr)->sync_with_stdio(false); 
	while(cin>>n)
	{
	if (solve())
	cout<<"Yes\n";
	else cout<<"No\n";
	}	
	
	return 0;
}
相关推荐
计算机安禾2 分钟前
【c++面向对象编程】第9篇:友元(friend):破坏封装的“特权”——真的有害吗?
java·c++·log4j
William_wL_27 分钟前
【C++】priority_queue(优先级队列)的使用和实现
c++
代码中介商28 分钟前
C++ STL入门:vector与字符串流详解
开发语言·c++
fqbqrr29 分钟前
2605C++,C++类的继承1
c++
王老师青少年编程33 分钟前
csp信奥赛C++高频考点专项训练之字符串 --【字符串排序】:[NOIP 1998 提高组] 拼数
c++·字符串·csp·高频考点·信奥赛·拼数·字符串排序
草莓熊Lotso35 分钟前
【Linux网络】从 0 到 1 实现高性能 UDP 聊天室:深入拆解 Linux 网络编程与线程池架构
linux·运维·服务器·网络·数据库·c++·udp
basketball61637 分钟前
C++ iomanip 常用函数
开发语言·c++
sanqima1 小时前
C++里strcpy()拷贝的3种写法
c++·字符串拷贝
艾莉丝努力练剑1 小时前
【Linux网络】Linux 网络编程:应用层自定义协议与序列化(2)序列化与反序列化
linux·运维·服务器·c++·网络协议·序列化
智者知已应修善业1 小时前
【51单片机一个按键切合初始流水灯按一下对半闪烁按一下显示时间】2023-10-16
c++·经验分享·笔记·算法·51单片机