fzu Problem - 2232 炉石传说(二分匹配)
题目链接:http://acm.fzu.edu.cn/problem.php?pid=2232
Description
GG学长虽然并不打炉石传说,但是由于题面需要他便学会了打炉石传说。但是传统的炉石传说对于刚入门的GG学长来说有点复杂,所以他决定自己开发一个简化版的炉石传说。
在简化版的炉石传说中:
每个随从只有生命值和攻击力,并且在你的回合下,你的每只随从在本回合下只能选择一个敌方随从进行攻击。当两个随从a,b交战时,a的生命值将减去b的攻击力,b的生命值将减去a的攻击力,(两个伤害没有先后顺序,同时结算)。如果a或b的生命值不大于0,该随从将死亡。
某一次对局中,GG学长和对手场面上均有n个随从,并且是GG学长的回合。由于GG学长是个固执的boy,他一定要在本回合杀死对方所有随从,并且保证自己的随从全部存活。他想知道能否做到。
Input
第一行为T,表示有T组数据。T<=100。
每组数据第一行为n,表示随从数量(1 <= n <= 100)
接下来一行2 * n个数字a1, b1, a2, b2, ... , an, bn (1 <= ai, bi <= 100)
表示GG学长的n个随从,ai表示随从生命,bi表示随从攻击力
接下来一行2 * n个数字c1, d1, c2, d2, ... , cn, dn (1 <= ci, di <= 100)
表示对手的n个随从,ci表示随从生命,di表示随从攻击力。
Output
每组数据,根据GG是否能完成他的目标,输出一行”Yes”或”No”。
Sample Input Sample Output
Yes
No
匈牙利算法:因为是一次性打败对方的所有人,所以要求学长的每个随从都要打败对手的随从,所以可以看成是匹配问题,找到最合适的匹配使得每一对都能符合条件,就是构造一个图,b[i][j] = 1表示学长的第i个随从和对手的第j个随从战斗后,随从i的生命力>0 随从j的生命力<=0,然后找到最大匹配是否是n即可;
*:第一次写的时候觉得就是简单的数学问题嘛,排好序记录下就好了,结果TLE了,( ▼-▼ ),看题目中范围都才100,真的没想过会超时
TLE代码:
#include<iostream>
#include<algorithm>
#include<cstdio>
#include<cstring>
#include<queue>
#include<stdlib.h>
#include<map>
#include<cmath> using namespace std; #define N 350
#define INF 0x3f3f3f3f struct node
{
int s,f,x;
}; node d[N],g[N]; bool cmp1(node a,node b)
{
return a.s<b.s;
} bool cmp2(node a,node b)
{
return a.f<b.f;
} int main()
{
int T,n,i; scanf("%d", &T); while(T--)
{
scanf("%d", &n); for(i=; i<n; i++)
scanf("%d %d", &g[i].s, &g[i].f);
for(i=; i<n; i++)
scanf("%d %d", &d[i].s, &d[i].f); sort(g,g+n,cmp1);
sort(d,d+n,cmp2); int ans=;
for(i=;i<n;i++)
{
while()
{
g[i].x=g[i].s-d[i].f;
d[i].x=d[i].s-g[i].f;
if(d[i].x<=&&g[i].x>)
{
ans++;
break;
}
if(d[i].x<=||g[i].x<=)
break;
}
} if(ans==n)
printf("Yes\n");
else
printf("No\n");
}
return ;
}
既然超时就只好往二分想了,然后就成了匹配题,( ▼-▼ ),二分匹配~~~
AC代码:
#include<iostream>
#include<algorithm>
#include<cstdio>
#include<cstring>
#include<queue>
#include<stdlib.h>
#include<map>
#include<cmath> using namespace std; #define N 350
#define INF 0x3f3f3f3f int v[N],vis[N],n, b[N][N]; struct node
{
int s,f;
}; node d[N],g[N]; int Find(int s)
{
int i; for(i=;i<=n;i++)
{
if(!v[i]&&b[s][i])
{
v[i]=;
if(!vis[i]||Find(vis[i]))
{
vis[i]=s;
return ;
}
}
}
return ;
} int main()
{
int T,i,j,x,y; scanf("%d", &T); while(T--)
{
memset(b,,sizeof(b)); scanf("%d", &n); for(i=; i<=n; i++)
scanf("%d %d", &g[i].s, &g[i].f);///GG学长
for(i=; i<=n; i++)
scanf("%d %d", &d[i].s, &d[i].f);///对手 for(i=;i<=n;i++)
for(j=;j<=n;j++)
{
x=g[i].s-d[j].f;
y=d[j].s-g[i].f;
if(x>&&y<=)
b[i][j]=;
} memset(vis,,sizeof(vis));
int ans=; for(i=;i<=n;i++)/**/
{
memset(v,,sizeof(v));
if(Find(i))
ans++;
} if(ans==n)
printf("Yes\n");
else
printf("No\n");
}
return ;
}
fzu Problem - 2232 炉石传说(二分匹配)的更多相关文章
- Problem 2232 炉石传说
Problem 2232 炉石传说 不知道fzu的账号在哪里弄,想要做题的可以到vj上面去做 https://vjudge.net/problem/FZU-2232 #include <iost ...
- nyoj 237 游戏高手的烦恼 二分匹配--最小点覆盖
题目链接:http://acm.nyist.net/JudgeOnline/problem.php?pid=237 二分匹配--最小点覆盖模板题 Tips:用邻接矩阵超时,用数组模拟邻接表WA,暂时只 ...
- HDU 3861 The King’s Problem(tarjan缩点+最小路径覆盖:sig-最大二分匹配数,经典题)
The King’s Problem Time Limit: 2000/1000 MS (Java/Others) Memory Limit: 65536/32768 K (Java/Other ...
- 【HDU 2255】奔小康赚大钱 (最佳二分匹配KM算法)
奔小康赚大钱 Time Limit: 1000/1000 MS (Java/Others) Memory Limit: 32768/32768 K (Java/Others)Total Subm ...
- hduoj-----(1068)Girls and Boys(二分匹配)
Girls and Boys Time Limit: 20000/10000 MS (Java/Others) Memory Limit: 65536/32768 K (Java/Others) ...
- HDU 4619 Warm up 2(2013多校2 1009 二分匹配)
Warm up 2 Time Limit: 3000/1000 MS (Java/Others) Memory Limit: 65535/32768 K (Java/Others)Total S ...
- HDU5093——Battle ships(最大二分匹配)(2014上海邀请赛重现)
Battle ships Problem DescriptionDear contestant, now you are an excellent navy commander, who is res ...
- Timus OJ 1997 Those are not the droids you're looking for (二分匹配)
题目链接:http://acm.timus.ru/problem.aspx?space=1&num=1997 这个星球上有两种人,一种进酒吧至少玩a小时,另一种进酒吧最多玩b小时. 下面n行是 ...
- hdu 1281棋盘游戏(二分匹配)
题目链接:http://acm.hdu.edu.cn/showproblem.php?pid=1281 Problem Description 小希和Gardon在玩一个游戏:对一个N*M的棋盘, ...
随机推荐
- $each $position $sort $slice
$push 向数组中添加元素 $each 循环数据(循环添加数据到数组) $sort 对数组进行排序(1:升序:-1:降序.) $slice 对整个collection表进行数据裁减,用的时候一定要当 ...
- 找斐波那契数列中的第N个数——递归与函数自调用算法
题目描述 Description 用递归的方法求斐波那契数列中的第N个数 输入输出格式 Input/output 输入格式:一行,一个正整数n输出格式: 一行,一个数,表示斐波那契数列中的第N个数 ...
- android打包大小笔录
版本 4.6.1 1-1 游戏完整包的大小 1-2 1级代码压缩 1-3 2级代码压缩 1-4 3级代码压缩 2-1 删除核心战斗的部分资源 2-2 2级代码压缩 3-0 删除外部UI的资源 剩下 ...
- (1)Two Sum--求数组中相加为指定值的两个数
Given an array of integers, find two numbers such that they add up to a specific target number. The ...
- CentOS环境搭建(JDK安装、mysql安装、hadoop安装等)
1.1准备权限:让普通用户具备sudo执行权限 切换到root用户,su # vi /etc/sudoers/ 添加 koushengrui ALL=(ALL) ALL 这里很容易 ...
- ADPCM编码和解码
原文:http://www.znmcu.cn/znx_51_alltest_shell_fj_adpcm1.html ADPCM音频解码,其实放在这里有些不太合适. 在编写ZN-X开发板整板测试程序的 ...
- 编译OpenGL代码时发生 Inconsistency detected by ld.so: dl-version.c: 224: _dl_check_map_versions: Assertion `needed != ((void *)0)' failed! 错误的解决方案
注:本解决方案适用于使用N卡的PC 出现该错误 , 一般是由于开源的nouveau驱动和Nvidia专有驱动冲突导致的 .在解决该问题时 , 尝试过卸载 N 卡专有驱动 , 仅使用开源nouveau驱 ...
- ios可变数组的所有操作
#pragma mark 创建数组c NSMutableArray * array =[[NSMutableArray alloc] initWithObjects:@"a",@& ...
- .net core 系列
1..net core 验证码 2..net core 导出excel 3..net core 上传文件 4..net core 时间戳转换 5..net core 读取配置文件 6..net cor ...
- mysql 1053错误,无法启动的解决方法
mysql 1053错误,无法启动的解决方法 windows2003服务器中,服务器重启后Mysql却没有启动,手动启动服务时提示1053错误. 尝试了以下方法,终于解决. 1.在DOS命令行使用 第 ...