省选九省联考T2 IIIDX(线段树)
题目传送门:https://www.luogu.org/problemnew/show/P4364
期中考后记:期中考刚考完,感觉不咋滴,年排第3。我抗压力太差了。。期末得把rank1抢回来。
本来感觉是个瞎贪心的(对每个歌曲的先决的歌曲为父子关系建树,然后每次找尽量大的孩子)。。其实不是。
贪心仅能骗60分。(省选题不会水的)
前面那个贪心只是瞎YY的。YY的贪心有一定几率出错。
为啥会出错,我一会儿讲。
我们正经得想一个贪心。其实问题变为:
for(i=1;i<=n;++i){
找一个难度为p的歌曲并删去,使在i后面的节点能依照没有p歌曲的歌单下不会没有难度足够大的歌曲的情况下,p尽量大,第i个歌曲难度就是p
}
其实这个贪心的思路非常好想(我最开始想的就是这个,后来去打暴力了,就用了第一个)
我们把设选了歌曲p后需要Ap个大于等于p的歌曲(包括p)。那么,我们只要计算出所有Ap,不就爽歪歪了吗?
最开始,我们将歌曲难度降序排序记为A,Ap=p。
写个伪代码
for(i=1;i<=n;++i){
找到最靠右的节点k使Ak-1<siz[i](i的子树大小)
ans[i]=k;
将ak+1.ak+2....an都减去siz[i];
}
for(i=1;i<=n;++i)输出d[ans[i]]
好了还记得最开始讲的贪心为啥会错吗?
因为,我刚才写的伪代码是错的(错的地方和第一个贪心一毛一样)
正确的在此
for(i=1;i<=n;++i){
找到最靠右的节点k使Ak-1<siz[i](i的子树大小)
如果相同的几个歌曲和k的难度一样,那么,将k移到在序列A中最靠左的那个;
ans[i]=k;
将ak+1.ak+2....an都减去siz[i];
}
为啥要那样干?反正没有后效性,而且贪心吗,就要贪得彻底,预留给自己的子树尽量多的节点。
代码:
#include <bits/stdc++.h>
using namespace std;
;
],dr[N<<],hd[N],pos,lovewxy[N];
double k;
bool cmp(int x,int y){return x>y;}
bool vis[N];
],wxy[rt<<|]);}
void pushdown(int rt){
if(dr[rt]){
dr[rt<<]+=dr[rt];
dr[rt<<|]+=dr[rt];
wxy[rt<<]+=dr[rt];
wxy[rt<<|]+=dr[rt];dr[rt]=;
}
}
void build(int rt,int l,int r){
if(l==r){
wxy[rt]=l;return;
}
;
build(rt<<,l,mid);build(rt<<|,mid+,r);pushup(rt);
}
void motify(int rt,int l,int r,int ql,int qr,int d){
if(ql<=l && r<=qr){
wxy[rt]+=d;dr[rt]+=d;return;
}pushdown(rt);
;
,l,mid,ql,qr,d);
<=qr)motify(rt<<|,mid+,r,ql,qr,d);
pushup(rt);
}
int query(int rt,int l,int r,int lst){
;
pushdown(rt);;
|]<lst)|,mid+,r,lst);
,l,mid,lst);
}
void dfs(int u){
if(u>n)return;
int l,r;double tmp=(double)u*k;
l=tmp-;
while(l<tmp)++l;
tmp=()*k;
r=tmp-;while(r<tmp)++r;
--r;siz[u]=;
for(int i=r;i>=l;--i)
if(i<=n)
dfs(i),siz[u]+=siz[i],fa[i]=u;
}
int main(){
scanf("%d%lf",&n,&k);
;i<=n;++i)scanf(,d++n,cmp);d[n+]=-;
;--i)hd[i]= d[i]==d[i+] ? pos:++pos;
;i<=n;++i)lovewxy[hd[i]]=max(lovewxy[hd[i]],i);
;
while(p>=k)
--p;
;--i){dfs(i);}build(,,n);
;i<=n;++i){
if(fa[i]&&!vis[fa[i]]){
motify(,,n,ans[fa[i]],n,siz[fa[i]]-);vis[fa[i]]=;
}
,,n,siz[i]);
tp=lovewxy[hd[tp]];
--lovewxy[hd[tp]];
ans[i]=tp;motify(,,n,ans[i],n,-siz[i]);
}
printf(]]);
;i<=n;++i)printf(" %d",d[ans[i]]);
}
省选九省联考T2 IIIDX(线段树)的更多相关文章
- [九省联考2018] IIIDX 线段树+贪心
题目: 给出 k 和 n 个数,构造一个序列使得 d[i]>=d[i/k] ,并且字典序最大. 分析: 听说,当年省选的时候,这道题挡住了大批的高手,看上去十分简单,实际上那道弯段时间内是转不过 ...
- [BZOJ5249][九省联考2018]IIIDX(线段树)
5249: [2018多省省队联测]IIIDX Time Limit: 40 Sec Memory Limit: 512 MBSubmit: 32 Solved: 17[Submit][Statu ...
- BZOJ5249 九省联考2018IIIDX(线段树+贪心)
显然这形成了一个树形结构.考虑这样一种贪心:按照曲目顺序,每次取消其父亲的预留,并选择当前可选择(保证其子树有合法选择且满足预留)的最大值,然后对其子树预留出大于等于他的一些值.这个做法显然是正确的. ...
- [luogu] P4364 [九省联考2018]IIIDX(贪心)
P4364 [九省联考2018]IIIDX 题目背景 Osu 听过没?那是Konano 最喜欢的一款音乐游戏,而他的梦想就是有一天自己也能做个独特酷炫的音乐游戏.现在,他在世界知名游戏公司KONMAI ...
- [BZOJ 5252][LOJ 2478][九省联考2018] 林克卡特树
[BZOJ 5252][LOJ 2478][九省联考2018] 林克卡特树 题意 给定一个 \(n\) 个点边带权的无根树, 要求切断其中恰好 \(k\) 条边再连 \(k\) 条边权为 \(0\) ...
- [九省联考2018]IIIDX
题目描述 这一天,Konano接到了一个任务,他需要给正在制作中的游戏<IIIDX>安排曲目的解锁顺序.游戏内共有n首曲目 ,每首曲目都会有一个难度d,游戏内第i首曲目会在玩家Pass第t ...
- 洛谷P4364 [九省联考2018]IIIDX 【线段树】
题目 [题目背景] Osu听过没?那是Konano最喜欢的一款音乐游戏,而他的梦想就是有一天自己也能做个独特酷炫的音乐游戏.现在 ,他在世界知名游戏公司KONMAI内工作,离他的梦想也越来越近了.这款 ...
- [luogu]P4364 [九省联考2018]IIIDX
题目背景 Osu 听过没?那是Konano 最喜欢的一款音乐游戏,而他的梦想就是有一天自己也能做个独特酷炫的音乐游戏.现在,他在世界知名游戏公司KONMAI 内工作,离他的梦想也越来越近了. 这款音乐 ...
- BZOJ.5249.[九省联考2018]iiidx(贪心 线段树)
BZOJ LOJ 洛谷 \(d_i\)不同就不用说了,建出树来\(DFS\)一遍. 对于\(d_i\)不同的情况: Solution 1: xxy tql! 考虑如何把这些数依次填到树里. 首先对于已 ...
随机推荐
- Linux下几种RTP协议实现的比较和JRTPLIB编程讲解
流媒体指的是在网络中使用流技术传输的连续时基媒体,其特点是在播放前不需要下载整个文件,而是采用边下载边播放的方式,它是视频会议. IP电话等应用场合的技术基础.RTP是进行实时流媒体传输的标准协议和关 ...
- 洛谷 P1187 3D模型
题目描述 一座城市建立在规则的n×m网格上,并且网格均由1×1正方形构成.在每个网格上都可以有一个建筑,建筑由若干个1×1×1的立方体搭建而成(也就是所有建筑的底部都在同一平面上的).几个典型的城市模 ...
- iPhone X机型适配
1.启动页 启动App,发现App只能居中显示,不能上下充满. 问题产生的原因是:iPhone X是5.8英寸,比5.5英寸的屏幕还要大,没有合适的启动页可以加载,所以只能使用以前5.5英寸的启动页, ...
- Hyperledger fablic 0.6 在centos7环境下的安装与部署
原文:http://blog.csdn.net/zhaoliang1131/article/details/54617274 Hyperledger Fabric超级账本 项目约定共同遵守的 基本原则 ...
- HDUj2612(两个起点找到最近的目的地)
Find a way Time Limit: 3000/1000 MS (Java/Others) Memory Limit: 32768/32768 K (Java/Others)Total ...
- mysql: not unique table/alias error. 如何解决
1.请检查出现问题位置的 SQL 语句中是否使用了相同的表名,或是定义了相同的表别名. 2.检查 SELECT 语句中要查询的字段名是不是定义重复,或者没有定义. 3.把你的sql语句中的换行去掉.一 ...
- hbase java API跟新数据,创建表
package hbaseCURD; import java.io.IOException; import org.apache.hadoop.conf.Configuration; import o ...
- centos 7之文件共享
一,安装过程 1.在VirtualBox的软件菜单里面选择 “设备”--“存储”,添加VBoxGuestAdditions.iso(在VirtualBox目录下). 2.在桌面上出现一个光驱 ...
- Spring的概况
----------------siwuxie095 Spring 的简介 Spring 是一个轻量级 控制反转(IoC) 和 面向切面(AOP) 的容器框架 年,它是为了解决企业应用开发的复杂性而诞 ...
- 洛谷P3380 【模板】二逼平衡树(树套树)(线段树+树状数组)
P3380 [模板]二逼平衡树(树套树) 题目描述 您需要写一种数据结构(可参考题目标题),来维护一个有序数列,其中需要提供以下操作: 查询k在区间内的排名 查询区间内排名为k的值 修改某一位值上的数 ...