5.出栈序列

第五题 出栈序列

题目描述

给定一个长度为 n n n的、仅由小写字母组成的字符串,将其按序依次放入栈中。
请问在所有可能的出栈序列中,字典序最小的出栈序列是多少?

输入格式

输入第一行, 一个正整数 n n n
输入第二行,一个长度为 n n n的字符串

输出格式

输出所有出栈序列中,字典序最小的出栈序列

数据范围

对于30%的数据, 1 ≤ n ≤ 10 1≤n≤10 1n10
对于60%的数据, 1 ≤ n ≤ 1 0 3 1≤n≤10^3 1n103
对于100%的数据, 1 ≤ n ≤ 1 0 5 1≤n≤10^5 1n105

样例数据

输入:

3
yes

输出:

esy

说明:

字符y、e、s依次进栈,所有出栈的可能性有:{yes}{yse}{eys}{esy}{sey}      其中 {esy} 的字典序最小

分析

思路一:

背景:会搜索的同学窃喜

可以利用搜索配合栈来搜出最优解。

代码:略

思路二:

背景:想想,当前你栈里有一个y,还有e,s要进栈,那y是出栈还是保留?

从样例来看是保留

why?

可以在入栈的e,s入手,发现e的字典序小于y的字典序
那么y显而易见要保留
可如果要进栈的字典序全大于y的字典序呢?
那y就是最小的,出栈!!
可进栈的字典序都和y的字典序一样呢?
反正得要保留一个,那肯定是出栈啦!!!!
利用一个新生没学过的技巧:葵花宝典最小后缀和,再搭配STL中的栈,就行了,不懂得STL栈的可以去看这里:

栈的应用

这是我自己写的,觉得不行就去网上找关于栈的文章

最后填上代码:

#include <bits/stdc++.h>
using namespace std;
const long long MAXN=1e5+10;

string st;
int n,x=0;
char a[MAXN];

int main(){
	cin>>n>>st;
	a[n-1]=st[n-1]; 
	for(int i=n-2;i>=0;--i){
		a[i]=min(st[i],a[i+1]);
	}
	stack <char> s;
	while(s.empty()!=true||x<n){
		if(s.empty()==true||x<n&&a[x]<s.top()){
			s.push(st[x++]);
		}
		else{
			cout<< s.top();
			s.pop();
		}
	}
	return 0;
}
在检查出栈序列的合法性时,可以使用一个辅助栈。具体步骤如下: 1. 遍历出栈序列依次取出每个数; 2. 对于每个取出的数,如果该数不等于辅助栈的栈顶元素,则将入栈序列中该数之前的所有数压入辅助栈中,并将该数弹出; 3. 如果该数等于辅助栈的栈顶元素,则将该数弹出; 4. 如果出栈序列遍历完毕后,辅助栈为空,则该出栈序列合法;否则,不合法。 例如,对于出栈序列为 4 5 3 2 1,入栈序列为 1 2 3 4 5,可以按以下步骤检查其合法性: 1. 取出出栈序列的第一个数 4,发现辅助栈为空,将入栈序列中 4 之前的所有数 1 2 3 压入辅助栈中; 2. 取出出栈序列的第二个数 5,发现辅助栈的栈顶元素为 3,不等于 5,于是将入栈序列中 5 之前的所有数 1 2 3 4 压入辅助栈中,并将 5 弹出; 3. 取出出栈序列的第三个数 3,发现辅助栈的栈顶元素为 3,相等,于是将 3 弹出; 4. 取出出栈序列的第四个数 2,发现辅助栈的栈顶元素为 2,不等于 2,于是将入栈序列中 2 之前的所有数 1 压入辅助栈中,并将 2 弹出; 5. 取出出栈序列的最后一个数 1,发现辅助栈的栈顶元素为 1,相等,于是将 1 弹出; 6. 出栈序列遍历完毕后,发现辅助栈为空,因此该出栈序列合法。 如果出栈序列为 4 3 5 1 2,入栈序列为 1 2 3 4 5,则在第二步取出 5 时,辅助栈的栈顶元素为 3,不等于 5,但是入栈序列中 5 之前的所有数已经压入了辅助栈中,因此无法继续匹配,最终辅助栈不为空,该出栈序列不合法。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

lyoi20210204

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值