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

大概的题意:

将 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;
}
相关推荐
石山代码11 分钟前
c++类型判断
开发语言·c++
雪度娃娃21 分钟前
结构型设计模式——代理模式
java·c++·设计模式·系统安全·代理模式
故事和你9123 分钟前
洛谷-【图论2-1】树2
开发语言·数据结构·c++·算法·动态规划·图论
kyle~1 小时前
C++---段错误(SIGSEGV)
linux·运维·c++·机器人
乐观勇敢坚强的老彭1 小时前
day515C++信奥循环嵌套强化03
开发语言·c++
杜子不疼.1 小时前
【C++ AI 大模型接入 SDK】 - 环境搭建
开发语言·数据库·c++
怀旧,1 小时前
【C++项目】负载均衡式在线OJ
开发语言·c++·负载均衡
MaikieMaiky1 小时前
C++ STL 系列(一):string 容器详解与示例
开发语言·c++
努力努力再努力wz1 小时前
【Qt入门系列】深入理解信号与槽:从事件响应到自定义信号机制
c语言·开发语言·数据结构·数据库·c++·qt·mysql
Hua-Jay1 小时前
OpenCV联合C++/Qt 学习笔记(二十)----Harri角点检测、Shi-Tomas角点检测及亚像素级别角点位置优化
c++·笔记·qt·opencv·学习·计算机视觉