博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
Codeforces Round #504 (rated, Div. 1 + Div. 2, based on VK Cup 2018 Final)-D. Array Restoration
阅读量:4114 次
发布时间:2019-05-25

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

D. Array Restoration

题意:给你一个有n个整数的数组,q次操作,第i次操作选择一个区间(不能为空)把这个区间里面的数都变成i(i>.=1&&i<=q),现在把这个变化过的数组中的一些数字变成0,问你能不能得到变成0之间的序列。如果序列可以恢复输出yes并且打印出这个序列,否则输出no

思路:通过分析我们可以判断序列无法恢复的情况,因为大的数字可以覆盖晓得数字,我们可以找到每个数字出现的区间,如果在这个区间里面有比他更小的数字,那么这个数字是无法恢复的,输出no。下面我们就开始恢复这个序列,我们从q开始恢复,如果q在变化后的序列总如果没有出现过,我们就要找到一个0,并用q代替这个0的位置,如果序列中没有0,那么这个序列是无法恢复的,因为每次选的区间不能为空,并且q是最后进行的操作,没有其他数字可以覆盖他,下面我们从小到大判断判断每个数字出现的区间里面有没有比他更小的数字出现,如果有就输出no,如果区间里面有0就把这个区间范围内的0变成当前询问的数字。我们可以使用线段树进行区间查询最小值

#include 
#include
#include
#include
#include
#include
#include
#include
#include
#include
#include
#include
#include
#include
using namespace std;const int maxn=2e5+50;int a[maxn];int Left[maxn];int Right[maxn];int minn[maxn*4];void PushUp(int rt){ minn[rt]=min(minn[rt*2],minn[rt*2+1]);}void Build(int l,int r,int rt){ if(l==r) { minn[rt]=a[l]; return ; } int mid=(l+r)/2; Build(l,mid,rt*2); Build(mid+1,r,rt*2+1); PushUp(rt);}void update(int x,int l,int r,int rt){ if(l==r) { minn[rt]=x; a[l]=x; return ; } int mid=(l+r)/2; if(minn[rt*2]==0) { update(x,l,mid,rt*2); } if(minn[rt*2+1]==0) { update(x,mid+1,r,rt*2+1); } PushUp(rt);}int query(int l,int r,int L,int R,int rt,int x){ if(l<=L&&r>=R) { if(minn[rt]==0) { update(x,L,R,rt); } return minn[rt]; } int mid=(L+R)/2; int ans=1e9; if(mid>=l) ans=min(ans,query(l,r,L,mid,rt*2,x)); if(mid
>n>>q; memset(minn,0,sizeof(minn)); for(int i=0; i<=q; i++) { Left[i]=n+1; Right[i]=0; } for(int i=1; i<=n; i++) { scanf("%d",&a[i]); Left[a[i]]=min(Left[a[i]],i); Right[a[i]]=max(Right[a[i]],i); } if(Left[q]>Right[q]) { if(Left[0]!=n+1) { Left[q]=Right[q]=Left[0]; a[Left[0]]=q; } else { printf("NO\n"); return 0; } } int flag=0; Build(1,n,1); for(int i=q; i>=1; i--) { if(Left[i]>Right[i]) continue; int temp=query(Left[i],Right[i],1,n,1,i); if(temp

 

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

你可能感兴趣的文章
Minimum Depth of Binary Tree -- 二叉树的最小深度 DFS 加剪枝
查看>>
Climbing Stairs 爬楼梯方法 动态规划
查看>>
Merge Two Sorted Lists 合并两个有序链表
查看>>
pow(x,n) 为什么错这么多次
查看>>
Jump Game 动态规划
查看>>
Binary Tree Maximum Path Sum 自底向上求解(重重重重)
查看>>
Subsets 深搜
查看>>
Subsets II
查看>>
Edit Distance 字符串距离(重重)
查看>>
Gray Code 格雷码
查看>>
对话周鸿袆:从程序员创业谈起
查看>>
web.py 0.3 新手指南 - 如何用Gmail发送邮件
查看>>
web.py 0.3 新手指南 - RESTful doctesting using app.request
查看>>
web.py 0.3 新手指南 - 使用db.query进行高级数据库查询
查看>>
web.py 0.3 新手指南 - 多数据库使用
查看>>
一步步开发 Spring MVC 应用
查看>>
python: extend (扩展) 与 append (追加) 的差别
查看>>
「译」在 python 中,如果 x 是 list,为什么 x += "ha" 可以运行,而 x = x + "ha" 却抛出异常呢?...
查看>>
谷歌阅读器将于2013年7月1日停止服务,博客订阅转移到邮箱
查看>>
浅谈JavaScript的语言特性
查看>>