BZOJ 5249: [2018多省省队联测]IIIDX(贪心 + 线段树)

题意

这一天,\(\mathrm{Konano}\) 接到了一个任务,他需要给正在制作中的游戏 \(\mathrm{《IIIDX》}\) 安排曲目 的解锁顺序。游戏内共有\(n\) 首曲目,每首曲目都会有一个难度 \(d\) ,游戏内第 \(i\) 首曲目会在玩家 Pass 第 \(\lfloor \frac{i}{k} \rfloor\) 首曲目后解锁( \(\lfloor x \rfloor\) 为下取整符号)若 \(\lfloor \frac{i}{k} \rfloor = 0\) ,则说明这首曲目无需解锁

举个例子:当 \(k = 2\) 时,第 \(1\) 首曲目是无需解锁的( \(\lfloor \frac{1}{2} \rfloor = 0\) ),第 \(7\) 首曲目需要玩家Pass 第 \(\lfloor \frac{7}{2} \rfloor= 3\) 首曲目才会被解锁。

\(\mathrm{Konano}\) 的工作,便是安排这些曲目的顺序,使得每次解锁出的曲子的难度不低于作为条件需要玩家通关的曲子的难度,即使得确定顺序后的曲目的难度对于每个 \(i\) 满足

\[d_i \geq d_{\lfloor \frac{i}{k} \rfloor}\]

当然这难不倒曾经在信息学竞赛摸鱼许久的 \(\mathrm{Konano}\) 。那假如是你,你会怎么解决这份任务呢?

\((1 \le n \le 500000, 1 \le k,d \le 10^9)\)

题解

一开始只想到了树上贪心的思路qwq 但是拍了几组就发现错了

原来是 \(d_i\) 互不相同的时候是对的 相同的时候就会被 \(hack\) 掉 这个很容易举出反例

还是简单讲一下贪心思路吧...

我们发现这个题目可以转化成一个树上问题 (因为每个点有且仅有一个父亲(前驱节点)和它有关系)

就是使得原序列字典序尽量大 并且每对父子要满足儿子权值大于等于父亲

不难发现这个我们直接把这棵树建出来 然后按后序遍历倒着分配编号就行了 (可以自行模拟一下qwq)

意思就是我们每次贪心地使得序列在前面的点字典序尽量大 并且 它后面有足够空间来分配的最优方案

这个可以用来做正解的思路 我们考虑 序列从前往后 单独考虑

我们肯定需要当前这个最优 但后面我们不能就草莽就做下决定

所以我们可以考虑 根的为子树预留空位 的贪心

这个我们举 题解 的一个例子来考虑吧

我们将原 \(d\) 数组降序排列 例如

\[9,8,7,6,5,5,5,5,4,3,2\]

我们令 \(F_i\) 表示第 \(i\) 个结点左边预留了的位置个数 那么 \((i-F_i)\) 就是 \(i\) 左边可用数的数量..

假设结点 \(1\) 的子树大小为 \(7\) 那么我第 \(1\) 个结点的值即为第 \(7\) 大的数 , \(5\)

我们把最右边的 \(5\) (第 \(9\) 位) 给第 \(1\) 个结点

那么我们需要在 \([1,8]\) 区间中预定 \(6\) 个数给第 \(1\) 个结点的子树

接着对于第 \(2\) 个结点 (设其子树大小为 \(s\) )

找到一个 尽量靠左 的位置 \(x\) ( 尽量大 ) 使得 \(x\) 右侧的可用数量都不少于 \(x\)

\[\displaystyle \min_{\forall i \ge x, (i-F_i) \ge s} x\]

而且到第 \(i\) 个点如果有父亲的话 , 父亲的预定额就可以去掉了 ( 只去掉一次 )

但保留父亲占的那一个位置就行了

然后这样就可以保证合法 并且 答案最优了

其实我想讲的是如何用线段树实现这个过程2333

我们其实只要开一颗支持 区间加减 + 区间最小值 的线段树就行了

维护一段区间 \(i-F_i\) 的最小值 我们就可以将那个 \(\forall\) 变成判一个了qwq

如果这段区间这个最小值不可行 并不直接代表整个区间不存在解 但代表如果整个区间全选上是不行的

然后我们取预定额的时候 把后面点需要预定的全都都减去那么多就行了

重点是如何查找那个尽量靠左的位置

你先考虑右区间是否可行 如果右区间 当前 不可行 那么左区间 整个 必不可行 那么直接去右区间看是否有解就行了

如果右区间全部都可行 那么我们去左区间看看是否可行 不进行回溯

如果左区间到底的话发现不可行 那么这个点 在原序列后一个就可行了

有一个小问题 如果这样预留的话 可能查的时候就把那个预留位置给占了啊qwq

但这种情况并不会出现的 因为你当前想要走到左子树 那么右子树必须全部满足

但你之前把右区间一个点直接减到不能走了 所以绝对是不可以出现这种情况的qwq (相当于右区间对左区间 \(chkmin\) )

代码

/**************************************************************Problem: 5249User: zjp_shadowLanguage: C++Result: AcceptedTime:5244 msMemory:28644 kb
****************************************************************/#include <bits/stdc++.h>
#define For(i, l, r) for(int i = (l), i##end = (r); i <= i##end; ++i)
#define Fordown(i, r, l) for(int i = (r), i##end = (l); i >= i##end; --i)
#define Set(a, v) memeset(a, v, sizeof(a))
using namespace std;inline bool chkmin(int &a, int b) { return b < a ? a = b, 1 : 0; }
inline bool chkmax(int &a, int b) { return b > a ? a = b, 1 : 0; }inline int read() {int x = 0, fh = 1; char ch = getchar();for (; !isdigit(ch); ch = getchar()) if (ch == '-') fh = -1;for (; isdigit(ch); ch = getchar()) x = (x * 10) + (ch ^ 48);return x * fh;
}void File() {freopen ("iiidx.in", "r", stdin);freopen ("iiidx.out", "w", stdout);
}double k;
const int N = 500100;#define lson o << 1, l, mid
#define rson o << 1 | 1, mid + 1, r
#define Del(o, v) tag[(o)] += (v), minv[(o)] -= (v);
struct Segment_Tree {int tag[N << 2], minv[N << 2];void push_down(int o) {if (!tag[o]) return; Del(o << 1, tag[o]); Del(o << 1 | 1, tag[o]); tag[o] = 0;}void push_up(int o) { minv[o] = min(minv[o << 1], minv[o << 1 | 1]); }void Build(int o, int l, int r) { tag[o] = 0 ; if (l == r) { minv[o] = l; return ; }int mid = (l + r) >> 1; Build(lson); Build(rson); push_up(o);}void Update(int o, int l, int r, int ul, int ur, int uv) {if (ul <= l && r <= ur) { Del(o, uv); return; }int mid = (l + r) >> 1; push_down(o);if (ul <= mid) Update(lson, ul, ur, uv);if (ur > mid) Update(rson, ul, ur, uv);push_up(o);}int Query(int o, int l, int r, int qv) {if (l == r) return (minv[o] >= qv ? l : l + 1);int mid = (l + r) >> 1, res = 0; push_down(o); if (minv[o << 1 | 1] >= qv) res = Query(lson, qv);else res = Query(rson, qv);push_up(o);return res;}
} T;int Num[N], n, a[N], Size[N], fa[N];
int ans[N], cnt[N];int main() {cin >> n >> k;For (i, 1, n) a[i] = read();sort(a + 1, a + 1 + n);reverse(a + 1, a + 1 + n);Fordown (i, n - 1, 1) if (a[i] == a[i + 1]) cnt[i] = cnt[i + 1] + 1;Fordown (i, n, 1) {++ Size[i];Size[fa[i] = floor(i / k)] += Size[i];}T.Build(1, 1, n);For (i, 1, n) {if (fa[i] && fa[i] != fa[i - 1]) T.Update(1, 1, n, ans[fa[i]], n, -(Size[fa[i]] - 1));int res = T.Query(1, 1, n, Size[i]);res += cnt[res]; ++ cnt[res]; res -= (cnt[res] - 1); ans[i] = res;T.Update(1, 1, n, res, n, Size[i]);}For (i, 1, n) printf ("%d ", a[ans[i]]);return 0;
}

转载于:https://www.cnblogs.com/zjp-shadow/p/8782872.html

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/251976.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

手眼标定

Eye-in-hand和Eye-to-hand问题求解和实验 2018年12月07日 00:00:40 百川木易 阅读数 3018 2018/12/5 By Yang Yang&#xff08;yangyangipp.ac.cn&#xff09; 本文所有源码和仿真场景文件全部公开&#xff0c;点击Gitee仓库链接。 文章目录 问题描述Eye-in-hand问题求解公式…

RNN总结

RNN既可以表述为循环神 经网络&#xff08;recurrent neural network&#xff09;&#xff0c;也可以表述为递归神经网络&#xff08;recursive neural network&#xff09;&#xff0c;前者一般用于处理以时间序列为输入的问题&#xff08;比如把一个句子看成词组成的序列&…

Problem 2. number题解

number&#xff1a;数学二分图匹配 首先&#xff0c;如果S<N,那么S1&#xff0c;S2...N这些数直接放在S1,S2...N的位置上(如果其他数x放在这些位置上面&#xff0c;这些数不放在对应位置&#xff0c;那么x一定能放在这些数放的位置&#xff0c;所以直接交换即可)所以可以直接…

SSD列子

一、介绍 本博文主要介绍实现通过SSD物体检测方式实现工件裂纹检测。裂纹图像如下所示&#xff1a; 二、关于SSD算法 具体算法不再阐述&#xff0c;详细请参考&#xff1a; https://blog.csdn.net/u013989576/article/details/73439202 https://blog.csdn.net/xiaohu2022/arti…

linux硬链接与软链接

Linux 系统中有软链接和硬链接两种特殊的“文件”。 软链接可以看作是Windows中的快捷方式&#xff0c;可以让你快速链接到目标档案或目录。 硬链接则透过文件系统的inode来产生新档名&#xff0c;而不是产生新档案。 创建方法都很简单&#xff1a; 软链接&#xff08;符号链接…

int转时间

int转时间 public static string FormatDuration(int duration) { if (duration 0) return "00:00:00"; int hours duration / 3600; int minutes duration % 3600 / 60; int seconds duration % 3600 % 60; string _hours hours.ToString("00") &qu…

企业级区块链现状研究报告:小企业的投资总额是大企业的28倍

根据企业级区块链现状研究报告表明&#xff0c;当前企业采用区块链技术的势头正在逐步增强。参与该报告的企业表示&#xff0c;区块链投资今年共增长了 62% &#xff0c;预计到 2025 年区块链将成为主流技术。其中&#xff0c;有 28% 的企业正在积极开展区块链发展计划。现在看…

特征匹配

Python 使用Opencv实现图像特征检测与匹配 2018-06-13 11:36:58 Xy-Huang 阅读数 19203更多 分类专栏&#xff1a; Python 人工智能 版权声明&#xff1a;本文为博主原创文章&#xff0c;遵循 CC 4.0 BY-SA 版权协议&#xff0c;转载请附上原文出处链接和本声明。 本文链接…

bzoj 1015 并查集

代码&#xff1a; //这题可以反着想&#xff0c;把要去掉的点倒着处理变成往图中一个一个的加点&#xff0c;然后用并查集处理联通快就好了。 #include<iostream> #include<cstdio> #include<cstring> #include<vector> using namespace std; const in…

页面中切换echarts主题

要做的效果是&#xff1a;点击下拉框切换echarts主题 下面是效果图&#xff1a; 项目环境&#xff1a; vue ts es6 echarts(4.2.1) 步骤 安装依赖&#xff0c; npm install echarts -S / yarn add echarts -S引入主题 参考链接选择下拉框中的主题时&#xff0c;拿到图表主题…

画极线

OpenCV学习日记5 2017-05-27 10:44:35 1000sprites 阅读数 2339更多 分类专栏&#xff1a; 计算机视觉 版权声明&#xff1a;本文为博主原创文章&#xff0c;遵循 CC 4.0 BY-SA 版权协议&#xff0c;转载请附上原文出处链接和本声明。 本文链接&#xff1a;https://blog.cs…

Win10开启Administrator超级管理员账户

方法1 1、在系统的开始菜单上&#xff0c;我们单击鼠标右键&#xff0c;然后选择计算机管理打开进入 2、打开的计算机管理窗口&#xff0c;点击本地用户和组中的用户打开&#xff0c;然后点击右侧的Administrator账户&#xff0c;双击鼠标打开进入 3、打开的属性窗口中&#xf…

Mysql异常问题排查与处理——mysql的DNS反向解析和客户端网卡重启

中午刚想趴一会&#xff0c;不料锅从天降&#xff01;&#xff01;&#xff01;Mysql连不上了。。。。。。。 现象如下&#xff1a; 现象1&#xff1a;登录mysql所在服务器&#xff0c;连接MySQL 成功&#xff1b; 现象2&#xff1a;通过客户端远程连接MySQL&#xff0c;返回失…

最近很火的MySQL:抛开复杂的架构设计,MySQL优化思想基本都在这

优化一览图 优化 笔者将优化分为了两大类&#xff1a;软优化和硬优化。软优化一般是操作数据库即可&#xff1b;而硬优化则是操作服务器硬件及参数设置。 1、软优化 1&#xff09;查询语句优化 首先我们可以用EXPLAIN或DESCRIBE(简写:DESC)命令分析一条查询语句的执行信息。 例…

【读书笔记】《深入浅出Webpack》

Webpack版本 分析版本为3.6.0 4.0为最近升级的版本&#xff0c;与之前版本变化较大&#xff0c;编译输出的文件与3.0版本会不一致&#xff0c;目前项目中使用的版本3.0版本&#xff0c;所以基于3.0版本进行分析学习。 Webpack构建流程 初始化&#xff1a;启动构建&#xff0c;读…

《JAVA与模式》之桥梁模式

在阎宏博士的《JAVA与模式》一书中开头是这样描述桥梁&#xff08;Bridge&#xff09;模式的&#xff1a; 桥梁模式是对象的结构模式。又称为柄体(Handle and Body)模式或接口(Interface)模式。桥梁模式的用意是“将抽象化(Abstraction)与实现化(Implementation)脱耦&#xff0…

LABLEME UPDATE DAMOD

Labelme的改进——海量图片的自动标注 深度学习一般需要对大量的图片进行标注&#xff0c;但是手动标注耗时耗力&#xff0c;所以模仿labelme软件的功能&#xff0c;使用程序对大批量的图片进行自动标注&#xff0c;大大减少手动操作。下面介绍如何实现对大批量的图片进行标…

Java基础教程:面向对象编程[2]

Java基础教程&#xff1a;面向对象编程[2] 内容大纲 访问修饰符 四种访问修饰符 Java中&#xff0c;可以使用访问控制符来保护对类、变量、方法和构造方法的访问。Java 支持 4 种不同的访问权限。 default (即缺省&#xff0c;什么也不写&#xff09;: 在同一包内可见&#xff…

【javascript】异步编年史,从“纯回调”到Promise

异步和分块——程序的分块执行 一开始学习javascript的时候&#xff0c; 我对异步的概念一脸懵逼&#xff0c; 因为当时百度了很多文章&#xff0c;但很多各种文章不负责任的把笼统的描述混杂在一起&#xff0c;让我对这个 JS中的重要概念难以理解&#xff0c; “异步是非阻塞的…

Shell编程之if语法练习(LNMP)全过程

大家好&#xff0c;我是延凯&#xff0c;本人原来在CSDN写作已经快一年了 都是相关Linux运维这方面的技术知识&#xff0c;现在搬到博客园也是我一直想的&#xff0c;本博客主要写Python&#xff0c;docker&#xff0c;shell等偏向开发云计算等知识点&#xff0c;谢谢各位&…