题目链接: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 炉石传说(二分匹配)的更多相关文章

  1. Problem 2232 炉石传说

    Problem 2232 炉石传说 不知道fzu的账号在哪里弄,想要做题的可以到vj上面去做 https://vjudge.net/problem/FZU-2232 #include <iost ...

  2. nyoj 237 游戏高手的烦恼 二分匹配--最小点覆盖

    题目链接:http://acm.nyist.net/JudgeOnline/problem.php?pid=237 二分匹配--最小点覆盖模板题 Tips:用邻接矩阵超时,用数组模拟邻接表WA,暂时只 ...

  3. 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 ...

  4. 【HDU 2255】奔小康赚大钱 (最佳二分匹配KM算法)

    奔小康赚大钱 Time Limit: 1000/1000 MS (Java/Others)    Memory Limit: 32768/32768 K (Java/Others)Total Subm ...

  5. hduoj-----(1068)Girls and Boys(二分匹配)

    Girls and Boys Time Limit: 20000/10000 MS (Java/Others)    Memory Limit: 65536/32768 K (Java/Others) ...

  6. 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 ...

  7. HDU5093——Battle ships(最大二分匹配)(2014上海邀请赛重现)

    Battle ships Problem DescriptionDear contestant, now you are an excellent navy commander, who is res ...

  8. 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行是 ...

  9. hdu 1281棋盘游戏(二分匹配)

    题目链接:http://acm.hdu.edu.cn/showproblem.php?pid=1281   Problem Description 小希和Gardon在玩一个游戏:对一个N*M的棋盘, ...

随机推荐

  1. Activity间切换的动画应用

    Activity切换过程中,系统会使用一些默认的动画,显得切换过程不至于太呆板. 在frameworks/base/core/res/res/values下的stlyes.xml文件中有具体的定义各个 ...

  2. HTTP SOAP Request

    public string SoapRequest(string url, string message, string type, Encoding encoding) { string resul ...

  3. sha加密算法

    密钥生成 公钥(e,n)  私钥(d,n) 找两个互质的大素数p和q, 计算n=p*p, f(n)=(p-1)*(q-1) 选择随机整数e(e和f(n)互质) de=f(n)mod 1 利用公钥加密 ...

  4. File文件操作类

    public class FileTest { //遍历出E:根目录下所有的文件夹,并输出文件夹名 static void testOne(){  //构建File对象,设置文件路径  File ro ...

  5. position:fixed 居中问题

    设置Css属性position:fixed后如何使这个盒子居中呢?其实也很简单: 就是需要设置给这个div盒子设置属性: left:0; right:0; margin:0 auto; ******* ...

  6. leetcode409

    Given a string which consists of lowercase or uppercase letters, find the length of the longest pali ...

  7. 《JS权威指南学习总结--toString()和valueOf()方法》

    方法要点: 一.toString()方法 1.主要用于Array.Boolean.Date.Error.Function.Number等对象转化为字符串形式.      数组类的toSting()方法 ...

  8. 缓存1 静态缓存-->读库保存成php文件 mkdir-->file_put_contents-->var_export -->include

    @mkdir()-->file_put_contents-->$data =  "<?php\nreturn ".var_export($setting, tru ...

  9. find the closest sum to a target value

    problem: given an array of integers including positive and negative, a target value. find 2 numbers ...

  10. php-fpm参数优化【转】

    转自 php-fpm参数优化 | Linux运维笔记https://blog.linuxeye.com/380.html php-fpm进程设置多少合适,设成动态还是静态? <lnmp一键安装包 ...