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的棋盘, ...
随机推荐
- RPM安装gcc gcc-c++扩展
rpm -ivh cpp--.el5.i386.rpm 回车 rpm -ivh kernel-headers--.el5.i386.rpm 回车 rpm -ivh glibc-headers-.i38 ...
- 接入支付宝出现交易订单处理失败,请稍后再试(ALI64)的错误【转】
接入第三方平台的时候,有时虽然按照文档来做,但是总是还会有各种各样的问题. 上次在接入支付宝的时候就碰到了交易订单处理失败,请稍后再试(ALI64)这样的错误,后来经过排查和总结,一般来讲这种问题都是 ...
- ubuntu14.04 安装 tensorflow
如果内容侵权的话,联系我,我会立马删了的-因为参考的太多了,如果一一联系再等回复,战线太长了--蟹蟹给我贡献技术源泉的作者们- 最近准备从理论和实验两个方面学习深度学习,所以,前面装好了Theano环 ...
- ZOJ 2158 POJ 1789 Truck History
最小生成树,主要是题目比较难懂. #include <cstdio> #include <cstring> #include <cmath> #include &l ...
- c语言_代码段_快说你是猪
/* 项目:快说你是猪 作者:landv 时间:2014年3月12日 编译环境:VS2013 */ #pragma warning(disable:4996) //全部关掉 #pragma warni ...
- python常用正则表达式
匹配特定数字:^[1-9]\d*//匹配正整数−[1−9]\d∗ //匹配负整数^-?[1-9]\d*//匹配整数[1−9]\d∗|0 //匹配非负整数(正整数 + 0)^-[1-9]\d*|0// ...
- lldpd-0.7.7代码解读(send_pdu部分)
此文档是经过逆序推到出的,可能有错误之处,敬请指教,谢谢. 1)interfaces_update 更新一些接口信息 2)levent_iface_subscribe 该接口通过socket通信(非阻 ...
- IoC容器Autofac正篇之解析获取(六)
解析获取的方式有如下几种: Resolve class Program { static void Main(string[] args) { var builder = new ContainerB ...
- LeetCode OJ 236. Lowest Common Ancestor of a Binary Tree
Given a binary tree, find the lowest common ancestor (LCA) of two given nodes in the tree. According ...
- 关于WIFI DIRECT功能的
http://processors.wiki.ti.com/index.php/WiFi_Direct_Configuration_Scripts#p2p_find https://wire ...