2018.9.26 2018NOIP冲刺之栈
最小字典序(stack)
输入序列中有 n 个正整数,栈 S 开始为空。
你每次只可以进行下面两种操作之一:① 将输入序列头端的数据移至 S 栈顶(进 S 栈);
② 将 S 栈顶元素输出并删除(退 S 栈)。
当然,输入序列非空时才可进行①操作,S 非空时才可进行②操作。
当①和②的操作都无法执行时,一定得到 n 个数据的一个输出序列。
由于①和②混搭的次序不同,导致相应的输出序列也各不相同,
请你求出能够得到的输出序列中字典序最小的一个序列。所谓字典序最小可以这样理解:首元素尽量小,在首元素最小的序列中第二元素尽可能小、在前 2 数据字典序最小的序列中,第三项尽可能小…,直至 n 项全部排完。
【输入输出说明】
输入文件 stack.in 第一行仅有一个正整数 n,表示输入序列中数据的个数。
第二行就是输入序列中依次排列的 n 个数据,相邻两数据间有一个空格。
输出文件 stack.out 中仅有一行 n 个数,就是字典序最小的输出序列,相邻整数间用一个空格隔开。
【输入输出样例】
stack.in:
4
2 3 1 4
stack.out:
1 3 2 4
【样例说明】
得到最小字典序的操作序列为:①①①②②②①②
【数据说明】
60%的数据 n<12;
80%的数据 n<1000;
100%的数据 n<100000,其他数据在 int 范围。
首先我们发现题目是区赛的第二个题,按照往年的惯例,第二个题以贪心模拟为主
而因为要求按照字典序输出,很明显应该满足前面的数尽可能小
于是我们得到了贪心思路:
(1)因为输入序列是单向的,所以可以使用一个idx表示当前处理到第几位
(2)每次查找从前往后最小的数,在这个数的位置压栈
(3)首先弹出第一个数,之后判断每一个栈顶的数是否小于后面最小的数
(4)若栈顶等于后面最小的数,因为输入序列是单向的,所以应该尽可能先弹出前面的数
(5)为了节约时间,初始化book数组,用book[i]表示第i个数至第n个数之间最小的数的最小编号(可以利用递推实现)
上代码:
#include<iostream>
#include<cstdio>
#include<algorithm>
#include<cmath>
#include<cstring>
#include<stack>
#define _ 0
#define olinr return
#define love_nmr 0
using namespace std;
int n,a[],book[],idx;
int main()
{
freopen("stack.in","r",stdin);
freopen("stack.out","w",stdout);
int i,j;
stack<int> s;
scanf("%d",&n);
for(i=;i<=n;i++)scanf("%d",&a[i]);
book[n]=n;
for(i=n-;i>=;i--)
{
if(a[i]<=a[book[i+]])book[i]=i;
else book[i]=book[i+];//初始化,若第i-1位置的数小于从第i至第n位置的数则更新book[i-1],否则延续
}
bool flag=false;//判断是否首位
while()
{
if(idx==n+)
{
while(!s.empty())
{
printf("%d ",s.top());
s.pop();
}
return ;
}//处理到输入序列最后一位,全部弹出
if(!flag)idx=,flag=true;
for(i=idx;i<=book[idx];i++)s.push(a[i]);//压栈
idx=i;//更新idx
if(!s.empty())
{
printf("%d ",s.top());
s.pop();//弹出栈顶
}
while(!s.empty()&&s.top()<=a[book[idx]])
{
printf("%d ",s.top());
s.pop();//继续弹出
}
}
olinr ~~love_nmr-(^_^);
}
比赛的时候就得了50分
后来发现把a[book[idx]]打成了book[idx] Q_Q
2018.9.26 2018NOIP冲刺之栈的更多相关文章
- 2018.11.2 2018NOIP冲刺之最短公共父串
很有意思的一个题 试题描述 给定字符串A和字符串B,要求找一个最短的字符串,使得字符串A和B均是它的子序列. 输入 输入包含两行,每行一个字符串,分别表示字符串A和字符串B.(串的长度不超过30) 输 ...
- 2018.10.20 2018NOIP冲刺之酒厂选址
题目传送门 明显能够看出有一个建图求路程的优化 然而发现10000*10000爆空间QAQ 为了做一些初始化方面的优化 我们发现了一个叫做前缀和的东西 可以在环上查到两个之间的最短距离 同时还要做一些 ...
- 2018.10.1 2018NOIP冲刺之立体图
2008NOIP普及组立体图 请自行百度(事实上放不下了) 图不是很清楚 下面有 [输入] 输入文件 drawing.in 第一行有用空格隔开的 2 个整数 m 和 n,表示有 m*n 个格子 (1 ...
- 2018.9.8 2018NOIP冲刺之配对
普及组第四题难度 主体思路竟然是贪心Q_Q 链接:https://www.nowcoder.com/acm/contest/164/D来源:牛客网 题目描述 小A有n个长度都是L的字符串.这些字符串只 ...
- OPPO Developers Conference(2018.12.26)
时间:2018.12.26地点:北京国家会议中心
- 2018.10.26 浪在ACM 集训队第四次测试赛
2018.10.26 浪在ACM 集训队第四次测试赛 题目一览表 来源 考察知识点 完成时间 A 生活大爆炸版 石头剪刀布 NOIP 提高组 2014 模拟??? 2018.11.9 B 联合 ...
- 微信小程序 - 接口更新记录以及解决方案(2018/12/26)
2018/8/17 - 背景音频需要在app.json添加requireBackGroundModes 2018/9/12 - 微信更改获取用户信息接口/获取位置等接口 - button 2018/1 ...
- 2018/4/26 python文件处理方式
目录 2018/4/26总结 1. 如果有一天群内问题总结: 问题:python2和python3的默认编码是什么? 2. python学习总结: python的处理文件方式 2018/4/26总结 ...
- 2018.10.26 浪在ACM 集训队第二次测试赛
2018.10.26 浪在ACM 集训队第二次测试赛 整理人:苗学林 A海港 参考博客:[1]:李继朋https://www.cnblogs.com/violet-acmer/p/9859006.ht ...
随机推荐
- Python 实现 淘宝秒杀 聚划算 自己主动提醒 源代码
说明 本实施例可以监视一起购买的成本button,当警报济济一堂花费时间整点到达(音频文件自定义位置)而自己主动跳出页面(URL习惯). 同一时候还能够通过命令行參数自己定义刷新间隔时间(默认0.1s ...
- 持续集成及部署利器:Go(不要和Google的编程语言Go混淆了!)
Go是一款先进的持续集成和发布管理系统,由ThoughtWorks开发.(不要和Google的编程语言Go混淆了!)其前身为CruiseControl,是ThoughtWorks在做咨询和交付交付项目 ...
- WPF中样式和行为和触发器
原文:WPF中样式和行为和触发器 样式简介:样式(style)是组织和重用格式化选项的重要工具,不是使用重复的标记填充XAML,以便设置外边距.内边距.颜色以及字体等细节.而是创建一系列封装所有这些细 ...
- DataTemplate
DataTemplate作用是布局+数据绑定 使用DataTemplate 同时完成样式布局和数据绑定 <Window.Resources> <DataTemplate x:Key= ...
- C#使用拉依达准则(3σ准则)剔除异常数据(.Net剔除一组数据中的奇异值)
原文:C#使用拉依达准则(3σ准则)剔除异常数据(.Net剔除一组数据中的奇异值) 1.问题的提出: 电池生产中,遇到一批电池的测量结果数据: 电压值 电池个数 电压值 电池个数 电压值 电池个数 电 ...
- 数据绑定(三)为Binding指定绑定源的几种方法
原文:数据绑定(三)为Binding指定绑定源的几种方法 Binding的源是数据的来源,所以,只要一个对象包含数据并能通过属性把数据暴露出来,它就能当作Binding的源来使用,常用的办法有: 一. ...
- 常用的shell(备份数据库、备份网站、切割访问日志)
备份网站程序 #!/bin/bash /bin/tar czf /mnt/backup_website/web_$(date +%Y%m%d_%H%M%S).gz.tar /mnt/wwwroot/w ...
- 微信小程序把玩(三十三)Record API
原文:微信小程序把玩(三十三)Record API 其实这个API也挺奇葩的,录音结束后success不走,complete不走,fail也不走, 不知道是不是因为电脑测试的原因,只能等公测或者等他们 ...
- wlan和wifi的区别是什么?
首先我们简单介绍下WLAN无线上网,其全称是:Wireless Local Area Networks,中文解释为:无线局域网络,是一种利用射频(Radio Frequency RF)技术进行据传输的 ...
- RedHat 7.3+ORACLE 12c RAC 使用udev绑定磁盘
在RedHat 7中,很多命令发生了改变,其中使用udev对磁盘绑定的命令也发生了变更,不再使用start_udev,而是改为了udevadm,下面具体介绍如何使用udev对磁盘进行绑定,这里对6和7 ...