BZOJ 3709&&AGC 018 C——多段排序的微扰法
BZOJ 3709
• 有n只怪物,你的初始生命值为z。
• 为了打败第i只怪物,你需要消耗cost[i]点生命值,但怪物死后
会使你恢复val[i]点生命值。
• 任何时候你的生命值都不能小于等于0。
• 问是否存在一种打怪顺序,使得你可以打完这n只怪物而不死掉
• n≤100,000
一些怪物是赚血的,一些是亏血的。
肯定要先打完所有赚血的,再打亏血的。
打赚血的:
为了保证能够有血,先打cos小的最保险。
微扰法证明:如果先打大一些的,如果能打,那么打小一些的也能打,而且血更多了,一定还能打那一个大的。
所以,先打小的一定不劣。
打亏血的:
为了保证能够有血,先打val大的最保险。
微扰法证明:为什么会出现一个方案能打,而另一个方案就打着打着就挂了呢?
一定有:life-cos1+val1-cos2<0并且life-cos2+val2-cos1>0
(显然,如果life-cos1<0且life-cos2>0的比较是没有必要的。因为处于减血的阶段,cos1就无论如何打不了了)
(所以只能是打了前一个,然后后一个不能打了)
即:life-cos2+val2-cos1>life-cos1+val1-cos2
那么,就有:val2>val1
并且,打1再打2和打2再打1之后的血量一致,不影响后面的。(也是微扰法的适用条件之一)
所以,当一个怪物的val更大的时候,先打它一定不劣。
用堆维护即可。
AGC 018 C
• 有X+Y+Z个人,每个人有Ai个金币,Bi个银币,Ci个铜币。现在
选X个人提供金币,Y个人提供银币,Z个人提供铜币。
• 求最多提供多少币。
• X+Y+Z≤100,000
话说直接跑费用流应该能过吧(虽然太暴力)
考虑如果只有金币银币。
如果1提供金币,2提供银币比换过来更优的话,有:A1+B2>A2+B1
A,B即金币银币。
移项:A1-B1>A2-B2
所以,按照A1-B1排序,前X个提供金币,后Y个提供银币。
现在加入铜币。
之前的努力不能白费。
所以我们在按照Ai-Bi排好序的数组上进行。
枚举一个分界点,i
[1,i]用A,C来填,[i+1,X+Y+Z]用C,B来填。
两半分别用刚才的类似的排序方法求出来答案。
可以用堆维护到logn
为什么是对的?
对于我们填好的一个方案:ACACC|BBBCBB
'|'代表分界点
1.由于按照Ai-Bi排好序,所以,A和B交换不优。
2.由于分界点内部是按照Ai-Ci,Bi-Ci排序的,所以内部的A,C和B,C交换已经考虑过。
3.如果A跨过分界点和一个C交换,ACCCC|BBBABB,那么由于按照Ai-Bi排好序,所以换成ACCCC|ABBBBB会更优。
这个情况会在枚举下一个分界点的时候考虑到。
4.B跨过分界点和C交换同理。
所以,对于这样的排序方法,再加上枚举,一定可以遍历所有的可能成为最优解的方案。
总结:
1.猜结论
2.列出比较的式子。
3.枚举一维也是降低复杂度和思维含量的重要方法。
BZOJ 3709&&AGC 018 C——多段排序的微扰法的更多相关文章
- [PA2014] [BZOJ 3709]~[BZOJ 3719] 合集
今天起尝试做套题喵~ (当然是因为被最大流的题目弄得恶心死了) 一共是 10 道题一道一道做 预计 3~4 内做完 尽情期待 [BZOJ 3709]Bohater 一眼就能感受到贪心的气息 因为很直观 ...
- BZOJ 3709: [PA2014]Bohater
3709: [PA2014]Bohater Time Limit: 5 Sec Memory Limit: 128 MBSec Special JudgeSubmit: 1050 Solved: ...
- 【贪心】bzoj 3709:[PA2014]Bohater
3709: [PA2014]Bohater Time Limit: 5 Sec Memory Limit: 128 MBSec Special JudgeSubmit: 653 Solved: ...
- mysql创建外键出错(注意数据库表字段排序)
1. 两个字段的类型或者大小不严格匹配.例如,如果一个是int(10),那么外键也必须设置成int(10),而不是int(11),也不能是tinyint.另外,你还必须确定两个字段是否一个为 sig ...
- BZOJ 1697: [Usaco2007 Feb]Cow Sorting牛排序
Description 农夫JOHN准备把他的 N(1 <= N <= 10,000)头牛排队以便于行动.因为脾气大的牛有可能会捣乱,JOHN想把牛按脾气的大小排序.每一头牛的脾气都是一个 ...
- BZOJ 2938: [Poi2000]病毒 [AC自动机 拓扑排序]
2938: [Poi2000]病毒 题意:判断是否存在无限长的不含模式串的字符串.只有01. 建出套路DP的转移图,判断有环就行了 练习一下拓扑排序 #include <iostream> ...
- [BZOJ 3709] Bohater
Description 在一款电脑游戏中,你需要打败n只怪物(从1到n编号).为了打败第i只怪物,你需要消耗d[i]点生命值,但怪物死后会掉落血药,使你恢复a[i]点生命值.任何时候你的生命值都不能降 ...
- bzoj 3709: [PA2014]Bohater 贪心
题目: 在一款电脑游戏中,你需要打败\(n\)只怪物(从\(1\)到\(n\)编号).为了打败第\(i\)只怪物,你需要消耗\(d_i\)点生命值,但怪物死后会掉落血药,使你恢复\(a_i\)点生命值 ...
- bzoj 3012: [Usaco2012 Dec]First! Trie+拓扑排序
题目大意: 给定n个总长不超过m的互不相同的字符串,现在你可以任意指定字符之间的大小关系.问有多少个串可能成为字典序最小的串,并输出这些串.n <= 30,000 , m <= 300,0 ...
随机推荐
- python学习笔记01 --------------hello world 与变量。
1.第一个程序: print('hello world') 输出结果: hello world 2.变量 2.1 变量的作用: 把程序运算的中间结果临时存到内存里,以备后面的代码继续调用. 2.2 变 ...
- Oracle 11g用exp无法导出空表的处理方法
Oracle 11G在用EXPORT导出时,空表不能导出. 11G中有个新特性,当表无数据时,不分配segment,以节省空间 解决方法: 1.insert一行,再rollback就产生segment ...
- angularjs工作原理解析
个人觉得,要很好的理解AngularJS的运行机制,才能尽可能避免掉到坑里面去.在这篇文章中,我将根据网上的资料和自己的理解对AngularJS的在启动后,每一步都做了些什么,做一个比较清楚详细的解析 ...
- 基于NABCD评论探路者团队贪吃蛇作品及改进建议
1.根据(不限于)NABCD评论作品的选题 N:随着人们生活压力越来越大,需要去去缓解压力,并且也需要不断进步,学习英语知识. A:它是基于java开发的一款软件,采用逐个吃字母,加长蛇身,增强记忆的 ...
- snprintf vs sprintf
#include <stdio.h> int printf(const char *format, ...); int fprintf(FILE *stream, const char * ...
- 软工实践第八次作业(课堂实战)- 项目UML设计(第五组)
本次作业博客 团队信息 队名:起床一起肝活队 原组长: 白晨曦(101) 原组员: 李麒 (123) 陈德斌(104) 何裕捷(214) 黄培鑫(217) 王焕仁(233) 林志华(128) 乐忠豪( ...
- android入门 — Service
Service完全在后台运行,没有用户界面.使用的时候先创建Service子类,然后在AndroidManifest.xml中进行注册,同时可以通过<intent-filter.../>进 ...
- .NET中的堆(Heap)和栈(Stack)的本质
计算机的内存可以分为代码块内存,Stack内存和Heap内存.代码块内存是在加载程序时存放程序机器代码的地方. 栈(Stack)一般存放函数内的局部变量. 堆(Heap)一般存放全局变量和类对象实例等 ...
- linux 虚拟网络模型介绍
第一种隔离模型 每一个虚拟机实例的网卡都有两个接口,一端接在虚拟机内部,一端接在宿主机内部,如上图所示eth0就是接在虚拟机内部的,而vnet0就是接在宿主机内部的,只要再创建一个虚 ...
- Java实现的词频统计——单元测试
前言:本次测试过程中发现了几个未知字符,这里将其转化为十六进制码对其加以区分. 1)保存统计结果的Result文件中显示如图: 2)将其复制到eclipse环境下的切分方法StringTokenize ...