HDU - 1962 二分图最大匹配模板(扑克牌得分最大)
题意:
直接说数据,第一行给定几组数据,每一组数据的第一行是两个人扑克牌分别的数量,第一行是亚当的扑克牌,第二行是夏娃的扑克牌,每一个扑克牌的大小用两个字符来表示,第一个表示是几号扑克牌,第二个表示扑克牌的花色(题中有给)
思路:
这是二分图最大匹配的模板题,二酚涂最大匹配需要用一个数组来记录匹配的路径。这里面是数组a,首先需要判断这两行的扑克牌互相之间的大小关系。然后以亚当手里的扑克牌为基准,枚举每一个扑克牌,如果对应的夏娃的扑克牌没有被其他扑克牌打败,或者将这个扑克牌打败的亚当的扑克牌有一条增广路,也就是说可以去打败其它的扑克牌。给这个扑克牌让位置,然后记录路径。
看代码:(比较好理解)
#include<stdio.h>
#include<map>
#include<string.h>
using namespace std;
char ya[50][3],xa[50][3];
int e[50][50];
map<char,int>M;
char c='C',d='D',s='S',h='H';
int pan(int i,int j)
{
if(ya[j][0]==xa[i][0])
{
if(M[xa[i][1]]>M[ya[j][1]])
return 1;
}
else
{
if(M[xa[i][0]]>M[ya[j][0]])
return 1;
}
return 0;
}
int n,a[110],book[110];
int dfs(int u)//第二行
{
for(int i=1; i<=n; i++)
{
if(book[i]==0&&e[u][i])
{
book[i]=1;
if(dfs(a[i])||a[i]==0)
{
a[i]=u;
return 1;
}
}
}
return 0;
}
int main()
{
M['A']=14,M['2']=2,M['3']=3,M['4']=4,M['5']=5;
M['6']=6,M['7']=7,M['8']=8,M['9']=9,M['T']=10;
M['J']=11, M['Q']=12, M['K']=13;
M[c]=1,M[d]=2,M[s]=3,M[h]=4;
int t;
scanf("%d",&t);
while(t--)
{
memset(e,0,sizeof(e));
memset(a,0,sizeof(a));//路径数组
scanf("%d",&n);
for(int i=1; i<=n; i++)
scanf("%s",ya[i]);
for(int i=1; i<=n; i++)
scanf("%s",xa[i]);
//printf("%d ****\n",pan(2,2));//第一个是夏娃,第二个是亚当
for(int i=1;i<=n;i++)
for(int j=1;j<=n;j++)
if(pan(i,j))
e[i][j]=1;
int sum=0;
for(int i=1; i<=n; i++)//从夏娃开始 第一列
{
memset(book,0,sizeof(book));
if(dfs(i))//增广路
sum++;
}
printf("%d\n",sum);
}
return 0;
}
HDU - 1962 二分图最大匹配模板(扑克牌得分最大)的更多相关文章
- 二分图最大匹配模板【匈牙利;Dinic最大流】
二分图最大匹配模板[匈牙利:Dinic最大流] 匈牙利算法 int n,m; vector<int> map[100010]; int match[100010];//保存匹配的互相点 b ...
- hdu 5727 二分图+环排列
Necklace Time Limit: 3000/1500 MS (Java/Others) Memory Limit: 65536/65536 K (Java/Others)Total Su ...
- 【HDU 2063】过山车(二分图最大匹配模板题)
题面 RPG girls今天和大家一起去游乐场玩,终于可以坐上梦寐以求的过山车了.可是,过山车的每一排只有两个座位,而且还有条不成文的规矩,就是每个女生必须找个个男生做partner和她同坐.但是,每 ...
- hdu 2255 二分图最大权匹配 *
题意:说在遥远的地方有一个非常富裕的村落,有一天,村长决定进行制度改革:重新分配房子.这可是一件大事,关系到人民的住房问题啊.村里共有n间房间,刚好有n家老百姓,考虑到每家都要有房住(如果有老百姓没房 ...
- hdu 2444(二分图) The Accomodation of Students
http://acm.hdu.edu.cn/showproblem.php?pid=2444 大意是给定n个学生,他们之间可能互相认识,首先判断能不能将这些学生分为两组,使组内学生不认识: 现想将学生 ...
- hdu 2063 二分图匹配
题意:一些女的和一些男的有好感,有好感的能一起坐过山车,问最多能组成多少对 hdu 11 页上少有的算法题,二分图匹配问题,匈牙利算法,对于每一个汉子,看和他有好感的妹子有没有配对了,没有配对过就可以 ...
- hdu 1281 二分图最大匹配
对N个可以放棋子的点(X1,Y1),(x2,Y2)......(Xn,Yn);我们把它竖着排看看~(当然X1可以对多个点~) X1 Y1 X2 Y2 X3 Y3 ..... Xn Yn ...
- HDU 1281 二分图
棋盘游戏 Time Limit: 2000/1000 MS (Java/Others) Memory Limit: 65536/32768 K (Java/Others)Total Submis ...
- *HDU 1068 二分图
Girls and Boys Time Limit: 20000/10000 MS (Java/Others) Memory Limit: 65536/32768 K (Java/Others) ...
随机推荐
- Git 程序员篇
关于 Git Git 背后的故事 伟大的作品总是诞生于伟大的时代,正如 Git 同样诞生于一个英雄辈出.极富纷争的年代. 2005 年,Linux 内核开发社区正面临严峻的挑战:他们不能继续使用 Bi ...
- 处理 Vue 单页面 SEO 的另一种思路
vue-meta-info 官方地址: https://github.com/monkeyWang... (设置vue 单页面meta info信息,如果需要单页面SEO,可以和 prerender- ...
- 一个轻量级的基于 .NET Core 的 ORM 框架 HSQL
HSQL 是一种轻量级的基于 .NET Core 的数据库对象关系映射「ORM」框架 HSQL 是一种可以使用非常简单且高效的方式进行数据库操作的一种框架,通过简单的语法,使数据库操作不再成为难事.目 ...
- DNA sequence HDU - 1560
DNA sequence Time Limit: 15000/5000 MS (Java/Others) Memory Limit: 32768/32768 K (Java/Others)Tot ...
- 【asp.net core】实现动态 Web API
序言: 远程工作已经一个月了,最近也算是比较闲,每天早上起床打个卡,快速弄完当天要做的工作之后就快乐摸鱼去了.之前在用 ABP 框架(旧版)的时候就觉得应用服务层写起来真的爽,为什么实现了个 IApp ...
- 面试被问分布式事务(2PC、3PC、TCC),这样解释没毛病!
整理了一些Java方面的架构.面试资料(微服务.集群.分布式.中间件等),有需要的小伙伴可以关注公众号[程序员内点事],无套路自行领取 更多优选 一口气说出 9种 分布式ID生成方式,面试官有点懵了 ...
- TCP粘包很难么,为何我屡屡受挫??
无论走到哪里,都应该记住,过去都是假的,回忆是一条没有尽头的路,一切以往的春天都不复存在,就连那最坚韧而又狂乱的爱情归根结底也不过是一种转瞬即逝的现实. --马尔克斯 本文已经收录至我的GitHub, ...
- Java 并发系列之一
Java 并发系列之一 简单的总结了一些 Java 常用的集合之后,发现许多集合都针对多线程提供了支持,比如 ConcurrentHashMap 使用分段锁来提高多线程环境下的性能表现与安全表现.所以 ...
- C++ 标准模板库(STL)-string
总结了一些c++ string库常用的库函数用法 #include <iostream> #include <string>//string类可以自动管理内存 using na ...
- throttle工具函数
// fn是我们需要包装的事件回调, delay是时间间隔的阈值 export function throttle(fn, delay) { // last为上一次触发回调的时间, timer是定时器 ...