题目传送门: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(线段树)的更多相关文章

  1. [九省联考2018] IIIDX 线段树+贪心

    题目: 给出 k 和 n 个数,构造一个序列使得 d[i]>=d[i/k] ,并且字典序最大. 分析: 听说,当年省选的时候,这道题挡住了大批的高手,看上去十分简单,实际上那道弯段时间内是转不过 ...

  2. [BZOJ5249][九省联考2018]IIIDX(线段树)

    5249: [2018多省省队联测]IIIDX Time Limit: 40 Sec  Memory Limit: 512 MBSubmit: 32  Solved: 17[Submit][Statu ...

  3. BZOJ5249 九省联考2018IIIDX(线段树+贪心)

    显然这形成了一个树形结构.考虑这样一种贪心:按照曲目顺序,每次取消其父亲的预留,并选择当前可选择(保证其子树有合法选择且满足预留)的最大值,然后对其子树预留出大于等于他的一些值.这个做法显然是正确的. ...

  4. [luogu] P4364 [九省联考2018]IIIDX(贪心)

    P4364 [九省联考2018]IIIDX 题目背景 Osu 听过没?那是Konano 最喜欢的一款音乐游戏,而他的梦想就是有一天自己也能做个独特酷炫的音乐游戏.现在,他在世界知名游戏公司KONMAI ...

  5. [BZOJ 5252][LOJ 2478][九省联考2018] 林克卡特树

    [BZOJ 5252][LOJ 2478][九省联考2018] 林克卡特树 题意 给定一个 \(n\) 个点边带权的无根树, 要求切断其中恰好 \(k\) 条边再连 \(k\) 条边权为 \(0\) ...

  6. [九省联考2018]IIIDX

    题目描述 这一天,Konano接到了一个任务,他需要给正在制作中的游戏<IIIDX>安排曲目的解锁顺序.游戏内共有n首曲目 ,每首曲目都会有一个难度d,游戏内第i首曲目会在玩家Pass第t ...

  7. 洛谷P4364 [九省联考2018]IIIDX 【线段树】

    题目 [题目背景] Osu听过没?那是Konano最喜欢的一款音乐游戏,而他的梦想就是有一天自己也能做个独特酷炫的音乐游戏.现在 ,他在世界知名游戏公司KONMAI内工作,离他的梦想也越来越近了.这款 ...

  8. [luogu]P4364 [九省联考2018]IIIDX

    题目背景 Osu 听过没?那是Konano 最喜欢的一款音乐游戏,而他的梦想就是有一天自己也能做个独特酷炫的音乐游戏.现在,他在世界知名游戏公司KONMAI 内工作,离他的梦想也越来越近了. 这款音乐 ...

  9. BZOJ.5249.[九省联考2018]iiidx(贪心 线段树)

    BZOJ LOJ 洛谷 \(d_i\)不同就不用说了,建出树来\(DFS\)一遍. 对于\(d_i\)不同的情况: Solution 1: xxy tql! 考虑如何把这些数依次填到树里. 首先对于已 ...

随机推荐

  1. ACM学习历程—广东工业大学2016校赛决赛-网络赛F 我是好人4(数论)

    题目链接:http://gdutcode.sinaapp.com/problem.php?cid=1031&pid=5 这个题目一看就是一道数论题,应该考虑使用容斥原理,这里对lcm进行容斥. ...

  2. Poj_1008--Maya Calendar

    一.Description 上周末,M.A. Ya教授对古老的玛雅有了一个重大发现.从一个古老的节绳(玛雅人用于记事的工具)中,教授发现玛雅人使用了一个一年有365天的叫做Haab的历法.这个Haab ...

  3. C语言中clock函数的使用

    #include<cstdio> #include<cstdlib> #include<ctime> using namespace std; int main() ...

  4. 【转】Pro Android学习笔记(二五):用户界面和控制(13):LinearLayout和TableLayout

    目录(?)[-] 布局Layout 线性布局LinearLayout 表格布局TableLayout 布局Layout Layout是容器,用于对所包含的view进行布局.layout是view的子类 ...

  5. RS485总线防雷保护方案

    RS485作为最为最常用的电表通讯方式之一.日常生活中雷电和静电干扰已经成为485通信总线在实际工程经常遇到的问题.故如何对芯片以及总线进行有效的保护,是摆在每一个使用者面前的一个问题.在这里,我们主 ...

  6. JS---改变图片大小

    <!DOCTYPE html> <html> <head lang="en"> <meta charset="UTF-8&quo ...

  7. Centos6.5安装JDK8教程(一)

    [原] 转载请注明原文地址, 保持对知识基本尊重,谢谢!   Win7宿主系统 VmWareWorkstation 11应用下的 Centos6.5系统.   /******************* ...

  8. 5种最流行的AI编程语言

    人工智能如今正是蓬勃发展的时期,许多开发者都在跃跃欲试,如果你写想转做AI相关的开发,那么来了解更多与AI开发有关的内容吧,本文将介绍创建AI程序时可以使用的5种最佳语言. 人工智能如今正是蓬勃发展的 ...

  9. Ubuntu Linux 使用桂电校园网 上网

    2016年9月1日 星期四 桂电校园网今天升级新的出校器,旧的出校器已经不能使用,所以本篇博客已经过期,下面的方法已经不能让Ubuntu使用桂电校园网上外网了.详细的原因,请到这个网站查看:校园网计费 ...

  10. cc和gcc

    cc就是一个链接文件连接到gcc中.只不过cc是unix中常用的编辑工具,而在linux中用的gcc.有一些在unix中写好的程序要放在linux中,所以要指定命令cc为gcc,其实一样.用where ...