「九省联考 2018」IIIDX 解题报告
「九省联考 2018」IIIDX
这什么鬼题,送的55分要拿稳,实测有60?
考虑把数值从大到小摆好,每个位置\(i\)维护一个\(f_i\),表示\(i\)左边比它大的(包括自己)还有几个数可以选
这个最开始直接处理好,就是>=数值\(i\)的数字个数
如果我们从小到大安排,发现我们需要给当前数安排一个数值,根据贪心,这个数值要尽可能大,但又要满足一个条件,就是这个数值右边的\(\min \{f_i\}\ge siz_{now}\)
安排完了以后,需要给子树再安排一下,就把右边区间的\(f_i\)做一个区间减
然后注意一个事情,进入子树以后,子树会去安排子树,所以在进子树第一个点后要把父亲的安排撤回。
感性一点理解的说,就是贪心的选一个可以选的最大值,需要保证还有一定数目的更大值可以在后面被选,但是你不知道到底这个后面的最大值怎么被选了,于是先维护好已经被选了一定个数这个信息,后面再去安排它。你现在安排它是为了排在它后面的同层点不去干扰它们
Code:
#include <cstdio>
#include <algorithm>
using std::min;
const int N=5e5+10;
const double eps=1e-6;
int n,d[N],b[N],par[N],pos[N],yuu[N],siz[N];
double k;
#define ls id<<1
#define rs id<<1|1
int mi[N<<2],tag[N<<2];
void build(int id,int l,int r)
{
if(l==r) {mi[id]=yuu[l];return;}
int mid=l+r>>1;
build(ls,l,mid),build(rs,mid+1,r);
mi[id]=min(mi[ls],mi[rs]);
}
void pushdown(int id)
{
if(tag[id])
{
mi[ls]+=tag[id];
mi[rs]+=tag[id];
tag[ls]+=tag[id];
tag[rs]+=tag[id];
tag[id]=0;
}
}
void ins(int id,int L,int R,int l,int r,int d)
{
if(l==L&&r==R)
{
mi[id]+=d;
tag[id]+=d;
return;
}
pushdown(id);
int Mid=L+R>>1;
if(r<=Mid) ins(ls,L,Mid,l,r,d);
else if(l>Mid) ins(rs,Mid+1,R,l,r,d);
else ins(ls,L,Mid,l,Mid,d),ins(rs,Mid+1,R,Mid+1,r,d);
mi[id]=min(mi[ls],mi[rs]);
}
int query(int id,int l,int r,int s)
{
if(l==r) return mi[id]>=s?l:l+1;
pushdown(id);
int mid=l+r>>1;
if(mi[rs]>=s) return query(ls,l,mid,s);
else return query(rs,mid+1,r,s);
}
int main()
{
scanf("%d%lf",&n,&k);
for(int i=1;i<=n;i++) scanf("%d",d+i),par[i]=1.0*i/k+eps;
std::sort(d+1,d+1+n);
int m=0,p=1;b[p]=d[n];
for(int i=1;i<=n;i++) if(d[i]!=d[i-1]) ++m;
for(int i=n-1;~i;i--)
if(d[i]!=d[i+1])
{
yuu[p]=n-i;
b[++p]=d[i];
}
build(1,1,m);
for(int i=n;i;i--) ++siz[i],siz[par[i]]+=siz[i];
for(int i=1;i<=n;i++)
{
if(par[i]&&par[i]!=par[i-1]) ins(1,1,m,pos[par[i]],m,siz[par[i]]-1);
pos[i]=query(1,1,m,siz[i]);
printf("%d ",b[pos[i]]);
ins(1,1,m,pos[i],m,-siz[i]);
}
return 0;
}
2019.3.18
「九省联考 2018」IIIDX 解题报告的更多相关文章
- loj2472 「九省联考 2018」IIIDX
ref #include <algorithm> #include <iostream> #include <cstdio> using namespace std ...
- LOJ #2473. 「九省联考 2018」秘密袭击
#2473. 「九省联考 2018」秘密袭击 链接 分析: 首先枚举一个权值W,计算这个多少个连通块中,第k大的数是这个权值. $f[i][j]$表示到第i个节点,有j个大于W数的连通块的个数.然后背 ...
- Loj #2479. 「九省联考 2018」制胡窜
Loj #2479. 「九省联考 2018」制胡窜 题目描述 对于一个字符串 \(S\),我们定义 \(|S|\) 表示 \(S\) 的长度. 接着,我们定义 \(S_i\) 表示 \(S\) 中第 ...
- LOJ 2743(洛谷 4365) 「九省联考 2018」秘密袭击——整体DP+插值思想
题目:https://loj.ac/problem/2473 https://www.luogu.org/problemnew/show/P4365 参考:https://blog.csdn.net/ ...
- 【LOJ】#2479. 「九省联考 2018」制胡窜
题解 老了,国赛之前敲一个后缀树上LCT和线段树都休闲的很 现在后缀树上线段树合并差点把我写死 主要思路就是后缀树+线段树合并+容斥,我相信熟练的OIer看到这已经会了 但就是不想写 但是由于我过于老 ...
- LOJ#2471「九省联考 2018」一双木棋 MinMax博弈+记搜
题面 戳这里 题解 因为每行取的数的个数是单调不增的,感觉状态数不会很多? 怒而记搜,结果过了... #include<bits/stdc++.h> #define For(i,x,y) ...
- [loj 2478][luogu P4843]「九省联考 2018」林克卡特树
传送门 Description 小L 最近沉迷于塞尔达传说:荒野之息(The Legend of Zelda: Breath of The Wild)无法自拔,他尤其喜欢游戏中的迷你挑战. 游戏中有一 ...
- @loj - 2478@「九省联考 2018」林克卡特树
目录 @description@ @solution@ @part - 1@ @part - 2@ @accepted code@ @details@ @description@ 小 L 最近沉迷于塞 ...
- [luogu] P4364 [九省联考2018]IIIDX(贪心)
P4364 [九省联考2018]IIIDX 题目背景 Osu 听过没?那是Konano 最喜欢的一款音乐游戏,而他的梦想就是有一天自己也能做个独特酷炫的音乐游戏.现在,他在世界知名游戏公司KONMAI ...
随机推荐
- mysql 无法退出sql命令行编辑
mysql 无法退出sql命令行编辑 | ANBOBhttp://www.anbob.com/archives/579.html mysql 无法退出sql命令行编辑 - 码农甲乙丙 - CSDN博客 ...
- Oracle通过ROWID删除表中重复记录
-- 1 通过ROWID删除T1表里重复的记录 SELECT ROWID,A,B--DELETE FROM T1WHERE ROWID IN ( SELECT RD FROM ( ...
- zTree树形菜单使用实例
在每个节点添加 id 和 pid, id 表示当前节点编号,pid 表示父节点编号 第一步:在页面显示菜单位置,添加 ul设置 class=”ztree” 第二步:开启简单数据格式支持 第三步:编写树 ...
- Linux 文件及目录管理命令基础
pwd 显示当前所在目录 cd 切换目录 cd 命令语法 cd [选项] 目录 cd 的常用选项: cd ~ /cd 切换到当前用户的加目录 cd . 保持当前目录不变 cd .. 切换到上级目录 ...
- 牛客练习赛13B 幸运数字2
题目链接:https://ac.nowcoder.com/acm/contest/70/B 题目大意: 略 分析: 先DFS求出所有幸运数,然后暴力即可 代码如下: #pragma GCC optim ...
- mongodb的安装方法
下载安装 mongodb官网下载地址:https://www.mongodb.org/downloads#produc...直接下载.msi文件并安装到指定目录即可.我的安装路径是D:\mongodb ...
- If you want an embedded database (H2, HSQL or Derby), please put it on the classpath.
学习Spring Boot 过程中遇到了下列这个问题 Description: Failed to configure a DataSource: 'url' attribute is not spe ...
- debug2
调试常用功能介绍 日常java开发中实际写代码的时间并不会很多,花在整理思路,代码重构,调试bug会占用很大部分时间. 熟练掌握调试工具,了解调试相关技巧,是java开发中减少调试时间,提高效率不可或 ...
- python之路--面向对象-成员
一 . 成员 在类中你能写的所有内容都是类的成员 class 类名: # 方法 def__init__(self, 参数1, 参数2...): # 属性变量 self.属性1 = 参数1 self.属 ...
- WPF实现Windows资源管理器(附源码)
今天我来写一篇关于利用WPF来实现Windows的资源管理器功能,当然只是局部实现这个功能,因为在很多时候我们需要来实现对本机资源的管理,当然我们可以使用OpenFileDialog dialog ...