贪心题目合集

1|0CF626G

题目链接

比较简单的贪心。

首先不去考虑修改操作,注意到这个条件我们可以看作有若干个物品,选取每个物品有 1 的代价和某个价值。有若干个限制条件是要选某一个必须要先选某个价值比他大的东西。根据贪心的原理这个限制条件其实跟没有一样,因为你不会先选价值小的东西。那么对于一个无修改的版本,我们可以考虑维护一个堆,每次取出堆顶,获得这次的价值,并对应修改再押一票的价值,直到 t 票全押上。

接下来考虑修改操作。一个直观的感受是单次修改不会影响太多的票,实际上是只有一张。具体证明可见 cz 的题解。我这里采用了在每次修改后做 B 次去掉删除后负贡献最小的和加入后正贡献最大的操作,B=20 时可以过。

2|0CF538H

题目链接

世界级贪心题。

一个首先的观察是,如果有三个老师两两无交,那就彻底完蛋了。然后世界级构造两个集合的大小 L=maxi=1nli,R=mini=1nri,开始分类讨论。

  • RL,意味着所有老师有交,所有人可以任意分组。
  • R<L,注意到此时不能再让 R 增大或 L 减小,否则均出现不合法情况。

所以现在 R 只能减小,L 只能增大。但不一定有 L+R[t,T]。接下来继续世界级讨论调整。

  • L+R[t,T],基于上面的讨论,改变 L,R 一定不优。直接判定即可。
  • L+Rt,基于上面的讨论,若为后一种情况,则 L 需要增大。否则若增大 R,则 L,R 必在交内,此时 R 的最优情况即为去在右端点,那么还是只能增大 L
  • L+R>T 同上。

综上,我们可以据此调整出 L,R,然后跑二分图匹配判定即可。

3|0CF573E

题目链接

很精妙的数据结构维护贪心。

一个想法是,每次选择当前对答案贡献最大的位置,然后直到贡献为负数。在这里,我们定义贡献为 vi=kiai+bi,其中 kii 之前选的数的个数加一,bii 后所选数的和。

对于这个贪心结论有个很厉害的证明,具体可以去看 chzhc 的题解。在这里略提一下。

Lemma:对于 ai>aji<j,选 i 之前不会选 j

证明考虑反证。假设 Lemma 不成立,第一次违法 Lemma 的操作对为 i,j,则讨论 i,j 之间有无已经被选的元素。无则 Lemma 成立。有则设其为 x。则有 axai>aj。然后再考虑 xvi,vj 的贡献,应分别为 ax,aj,此时有 vi>vj,Lemma 成立。

然后可以通过 Lemma 证明贪心结论成立(其实是不想看了/cf)。

考虑快速维护这个贪心。每次选一个位置 x 对后面的位置 i 都有一个 ai 的贡献,对前面的位置有一个 ax 的贡献。分块维护这个,每个块内维护 k,b 分别表示块外 i 之前选的数的个数加一和块外 i 后选的数字和。每次问出所有块的最大值,然后对前后暴力修改,块内重构贡献即可。

现在的问题是如何快速求最大值。注意到两个操作均不会使整块操作的凸包形态改变,那么我们对于初始块暴力重构,其余块打标记即可。


__EOF__

本文作者EXODUS
本文链接https://www.cnblogs.com/-Complex-/p/17552506.html
关于博主:评论和私信会在第一时间回复。或者直接私信我。
版权声明:本博客所有文章除特别声明外,均采用 BY-NC-SA 许可协议。转载请注明出处!
声援博主:如果您觉得文章对您有帮助,可以点击文章右下角推荐一下。您的鼓励是博主的最大动力!
posted @   -Comρℓex-  阅读(80)  评论(1编辑  收藏  举报
相关博文:
阅读排行:
· 地球OL攻略 —— 某应届生求职总结
· 周边上新:园子的第一款马克杯温暖上架
· Open-Sora 2.0 重磅开源!
· 提示词工程——AI应用必不可少的技术
· .NET周刊【3月第1期 2025-03-02】
点击右上角即可分享
微信分享提示