博客
关于我
C. Minimal string(思维+贪心+细节)
阅读量:241 次
发布时间:2019-03-01

本文共 815 字,大约阅读时间需要 2 分钟。


题意:给出一个字符串,按照从前到后的顺序进栈,输出字典序最小的出栈序列

思路:最开始贪心,预处理一个后缀,看是否存在比栈顶更小的。有就按下不放出来。然后wa17...以为贪心不行。改成一个处理每个位置的next,然后26枚举到最后能放。最后倒序一遍。依然wa17.

然后发现,栈顶之下的元素虽然比栈顶大,但是不一定比后缀大,这边要while不停的判一下栈顶。

#include
#include
#include
#include
#include
#include
#include
#include
#include
#include
#define debug(a) cout<<#a<<"="<
<
s;int main(void){ cin.tie(0);std::ios::sync_with_stdio(false); cin>>(str+1);LL n=strlen(str+1); memset(suf,0x3f,sizeof(suf)); for(LL i=n;i>=1;i--){ suf[i]=min(suf[i+1],(LL)(str[i]-'a'+1)); } vector
v; for(LL i=1;i<=n;i++){ if(s.empty()){ s.push(str[i]); } else{ while(!s.empty()){ if((s.top()-'a'+1)<=suf[i]){ v.push_back(s.top()); s.pop(); } else break; } s.push(str[i]); } } while(!s.empty()){ v.push_back(s.top());s.pop(); } for(auto i:v){ cout<

 

转载地址:http://eict.baihongyu.com/

你可能感兴趣的文章
MySQL5.6忘记root密码(win平台)
查看>>
MySQL5.6的Linux安装shell脚本之二进制安装(一)
查看>>
MySQL5.6的zip包安装教程
查看>>
mysql5.7 for windows_MySQL 5.7 for Windows 解压缩版配置安装
查看>>
Webpack 基本环境搭建
查看>>
mysql5.7 安装版 表不能输入汉字解决方案
查看>>
MySQL5.7.18主从复制搭建(一主一从)
查看>>
MySQL5.7.19-win64安装启动
查看>>
mysql5.7.19安装图解_mysql5.7.19 winx64解压缩版安装配置教程
查看>>
MySQL5.7.37windows解压版的安装使用
查看>>
mysql5.7免费下载地址
查看>>
mysql5.7命令总结
查看>>
mysql5.7安装
查看>>
mysql5.7性能调优my.ini
查看>>
MySQL5.7新增Performance Schema表
查看>>
Mysql5.7深入学习 1.MySQL 5.7 中的新增功能
查看>>
Webpack 之 basic chunk graph
查看>>
Mysql5.7版本单机版my.cnf配置文件
查看>>
mysql5.7的安装和Navicat的安装
查看>>
mysql5.7示例数据库_Linux MySQL5.7多实例数据库配置
查看>>