BZOJ 3983 Takeover Wars 解题报告
我猜了一个结论,能合并就合并,到了必须要敌对交易的时候才进行敌对交易。
然后合并的话,肯定是拿最大的两个去合并。
至于敌对交易,肯定是干掉对方最大的公司才是有意义的。
于是各种分类讨论。。。看代码好了。。。
#include <cmath>
#include <queue>
#include <cstdio>
#include <cstring>
#include <iostream>
#include <algorithm>
using namespace std;
typedef long long LL;
#define N 100000 + 5 int _, n, m;
priority_queue <LL> Q[]; inline LL getint()
{
char ch = '\n';
for (; ch > '' || ch < ''; ch = getchar()) ;
LL res = ch - '';
for (ch = getchar(); ch >= '' && ch <= ''; ch = getchar())
res = (res << ) + (res << ) + ch - '';
return res;
} inline bool Solve() // 返回赢家的编号 (0 或 1)
{
for (int op = ; ; op ^= )
{
if (Q[op].empty()) return op ^ ; // Section 1 : 如果当前公司没有分公司了,自然赢家是对方。
if (Q[op].size() == ) // Section 2 : 如果当前公司只剩一个分公司
{
if (Q[op].top() < Q[op ^ ].top()) // Case 1 : 如果对方最值钱的公司比自己这个公司还值钱,自然赢家是对方。
return op ^ ;
else if (Q[op].top() == Q[op ^ ].top() && Q[op ^ ].size() == ) // Case 2 : 两边都只剩一个分公司,而且价值都一样,那么平局,赢家算后手。
return ;
else if (Q[op].top() > Q[op ^ ].top()) Q[op ^ ].pop(); // Case 3 : 这里只能进行敌对交易。
}
else // Section 3 : 如果当前公司有很多分公司
{
LL Max_1 = Q[op].top();
Q[op].pop();
LL Max_2 = Q[op].top();
Q[op].push(Max_1);
if (Q[op ^ ].size() == ) // Case 1 : 如果对方只有一个分公司,那么当前公司只管合并就行了。
{
Q[op].pop(), Q[op].pop();
Q[op].push(Max_1 + Max_2);
}
else
{
LL _Max_1 = Q[op ^ ].top();
if (_Max_1 >= Max_1) // Case 2 : 如果当前公司最大的分公司不及对方最大的分公司,那么只能合并。
{
Q[op].pop(), Q[op].pop();
Q[op].push(Max_1 + Max_2);
}
else
{
Q[op ^ ].pop();
LL _Max_2 = Q[op ^ ].top();
Q[op ^ ].push(_Max_1);
if (_Max_1 + _Max_2 >= Max_1 + Max_2)
{ // Case 3 : 如果当前公司前两大的分公司价值和小于等于对方前两大的分公司价值和,那必须要敌对交易了,否则主动权就不在自己这边了。
Q[op ^ ].pop();
}
else // Case 4 : 如果当前公司前两大的分公司价值和大于对方前两大的分公司价值和,那么就算合并了主动权也在自己这边,那就合并呗。
{
Q[op].pop(), Q[op].pop();
Q[op].push(Max_1 + Max_2);
}
}
}
}
}
} int main()
{
#ifndef ONLINE_JUDGE
freopen("3983.in", "r", stdin);
freopen("3983.out", "w", stdout);
#endif while (scanf("%d%d", &n, &m) == )
{
while (!Q[].empty()) Q[].pop();
while (!Q[].empty()) Q[].pop();
for (int i = ; i <= n; i ++) Q[].push(getint());
for (int i = ; i <= m; i ++) Q[].push(getint());
bool winner = Solve();
printf("Case %d: ", ++ _);
puts(winner == ? "Takeover Incorporated" : "Buyout Limited");
} #ifndef ONLINE_JUDGE
fclose(stdin);
fclose(stdout);
#endif
return ;
}
BZOJ 3983 Takeover Wars 解题报告的更多相关文章
- BZOJ 4619 Swap Space 解题报告
今天是因为David Lee正好讲这个题的类似题,我才做了一下. 本题是world final 2016的一道水…… 题目地址如下 http://www.lydsy.com/JudgeOnline/p ...
- BZOJ 2839: 集合计数 解题报告
BZOJ 2839: 集合计数 Description 一个有\(N\)个元素的集合有\(2^N\)个不同子集(包含空集),现在要在这\(2^N\)个集合中取出若干集合(至少一个),使得 它们的交集的 ...
- BZOJ 1367 [Baltic2004]sequence 解题报告
BZOJ 1367 [Baltic2004]sequence Description 给定一个序列\(t_1,t_2,\dots,t_N\),求一个递增序列\(z_1<z_2<\dots& ...
- BZOJ 1044 木棍分割 解题报告(二分+DP)
来到机房刷了一道水(bian’tai)题.题目思想非常简单易懂(我的做法实际上参考了Evensgn 范学长,在此多谢范学长了) 题目摆上: 1044: [HAOI2008]木棍分割 Time Limi ...
- BZOJ 4341 [CF253 Printer] 解题报告
乍一看这个题好像可以二分优先度搞搞... 实际上能不能这么搞呢...? 我反正不会... 于是开始讲我的乱搞算法: 首先肯定要把任务按照优先度排序. 用一棵在线建点的线段树维护一个时刻是否在工作. 然 ...
- BZOJ 4036 [HAOI2015] Set 解题报告
首先我们不能一位一位的考虑,为什么呢? 你想想,你如果一位一位地考虑的话,那么最后就只有 $n$ 个数字,然而他给了你 $2^n$ 个数字,怎么看都不对劲呀.(我是因为这样子弄没过样例才明白的) 所以 ...
- BZOJ 3288 Mato矩阵 解题报告
这个题好神呀..Orz taorunz 有一个结论,这个结论感觉很优美: $$ans = \prod_{i=1}^{n}\varphi(i)$$ 至于为什么呢,大概是这样子的: 对于每个数字 $x$, ...
- BZOJ 4123 [Baltic2015] Hacker 解题报告
首先,Alice 会选择一个长度为 $\lfloor\frac{n+1}{2}\rfloor$ 的区间,我们把这个长度记为 $len$. 有这么一个结论:令 $F_i$ 为覆盖 $i$ 点的所有长度为 ...
- BZOJ 4146 [AMPPZ2014] Divisors 解题报告
这个题感觉比较小清新... 我们记录每个数出现的次数 $T_i$. 首先依次枚举每个数字,令 $ans = ans + T_i \times (T_i - 1)$,然后枚举这个数的倍数,令 $ans ...
随机推荐
- deepin linux安装与配置
作者:相思羽 出处:http://www.cnblogs.com/xiang-siyu 欢迎转载,也请保留这段声明.谢谢! deepin linux是由深度开发的操作系统,基于debian,内置了搜 ...
- SpringMVC框架
一.SpringMVC工作流程图 DispatcherServlet:Spring提供的前端控制器,所有的请求都有经过它来统一分发.在DispatcherServlet将请求分发给Spring Con ...
- 关于php的两个符号@和$
在写代码的时候,碰到了在函数和变量前家 @和$的的问题,于是就借这个机会,学习下php的传值和传引用这两种方式 首先 @ 运算符只对表达式有效.对新手来说一个简单的规则就是:如果能从某处得到值,就能在 ...
- 【转】MyBatis学习总结(四)——解决字段名与实体类属性名不相同的冲突
[转]MyBatis学习总结(四)——解决字段名与实体类属性名不相同的冲突 在平时的开发中,我们表中的字段名和表对应实体类的属性名称不一定都是完全相同的,下面来演示一下这种情况下的如何解决字段名与实体 ...
- Spring AOP (Spring 3.x 企业应用开发实战读书笔记第六章)
从面相对象编程到面相切面编程,是一种代码组织方式的进化. 每一代的代码组织方式,其实是为了解决当时面对的问题.比如写编译器和写操作系统的时候的年代当然要pop,比如写界面的时候当然要oop,因为界面这 ...
- (十一)Hibernate 高级配置
第一节:配置数据库连接池 反问数据库,需要不断的创建和释放连接,假如访问量大的话,效率比较低级,服务器消耗大: 使用数据库连接池,我们可以根据实际项目的情况,定义连接池的连接个数,从而可以实现从连接池 ...
- .Net 程序集 签名工具sn.exe 密钥对SNK文件 最基本的用法
阐述签名工具这个概念之前,我先说说它不是什么: 1.它不是用于给程序集加密的工具,它与阻止Reflector或ILSpy对程序集进行反编译一毛钱关系都没有. 2.它很讨厌人们把它和加密联系在一起. 我 ...
- web前端面试题收集(一)
CSS中margin和padding的区别? Javascript中如何检测一个变量是一个String类型?请写出函数实现. 网页中实现一个计算当年还剩多少时间的倒计时程序,要求网页上实时动态显示“x ...
- 九度OJ 1056--最大公约数 1439--Least Common Multiple 【辗转相除法】
题目地址:http://ac.jobdu.com/problem.php?pid=1056 题目描述: 输入两个正整数,求其最大公约数. 输入: 测试数据有多组,每组输入两个正整数. 输出: 对于每组 ...
- C++实现一个单例模板类
单例模式在项目开发中使用得比较多,一个单例的模板类显得很有必要,避免每次都要重复定义一个单例类型 //非多线程模式下的一个单例模板类的实现 // template_singleton.h #inclu ...