棋盘游戏

Time Limit: 2000/1000 MS (Java/Others)    Memory Limit: 65536/32768 K (Java/Others)
Total Submission(s): 7898    Accepted Submission(s): 4600

Problem Description
小希和Gardon在玩一个游戏:对一个N*M的棋盘,在格子里放尽量多的一些国际象棋里面的“车”,并且使得他们不能互相攻击,这当然很简单,但是Gardon限制了只有某些格子才可以放,小希还是很轻松的解决了这个问题(见下图)注意不能放车的地方不影响车的互相攻击。 
所以现在Gardon想让小希来解决一个更难的问题,在保证尽量多的“车”的前提下,棋盘里有些格子是可以避开的,也就是说,不在这些格子上放车,也可以保证尽量多的“车”被放下。但是某些格子若不放子,就无法保证放尽量多的“车”,这样的格子被称做重要点。Gardon想让小希算出有多少个这样的重要点,你能解决这个问题么?
 
Input
输入包含多组数据, 
第一行有三个数N、M、K(1<N,M<=100 1<K<=N*M),表示了棋盘的高、宽,以及可以放“车”的格子数目。接下来的K行描述了所有格子的信息:每行两个数X和Y,表示了这个格子在棋盘中的位置。
 
Output
对输入的每组数据,按照如下格式输出: 
Board T have C important blanks for L chessmen.
 
Sample Input
3 3 4
1 2
1 3
2 1
2 2
3 3 4
1 2
1 3
2 1
3 2
 
Sample Output
Board 1 have 0 important blanks for 2 chessmen.
Board 2 have 3 important blanks for 3 chessmen.
 
Author
Gardon
 
Source
 
Recommend
lcy
 
 /*************************************************************************
> File Name: hdu-1281.棋盘游戏.cpp
> Author: CruelKing
> Mail: 2016586625@qq.com
> Created Time: 2019年08月28日 星期三 09时49分22秒
本题思路:本题的重点在于如何求解重要边,最简单的思路就是枚举所有边,如果去掉一条边之后发现最大匹配数目减少了,则说明这条边所对应的点就是关键点。
其次还有一种复杂度更低的思路,就是对于每个已经匹配过的边,先删除这条边,我们以所有没有匹配过的顶点为起点再去匹配边,如果发现可以匹配到那么就说明还可以找到其他增广路,意思就是可以有别的匹配边代替这条匹配边,那么这个点就不是关键点,否则这个点就是关键点。
************************************************************************/
/*
#include <cstdio>
#include <cstring>
using namespace std; const int maxn = 100 + 5, maxm = 100 * 100 + 5;
int linker[maxn], ui[maxn], vi[maxn];
bool used[maxn], g[maxn][maxn];
int n, m; bool dfs(int u) {
for(int v = 1; v <= m; v ++) {
if(g[u][v] && !used[v]) {
used[v] = true;
if(linker[v] == -1 || dfs(linker[v])) {
linker[v] = u;
return true;
}
}
}
return false;
} int hungary() {
int res = 0;
memset(linker, -1, sizeof linker);
for(int i = 1; i <= n; i ++) {
memset(used, false, sizeof used);
if(dfs(i)) res ++;
}
return res;
} int main() {
int k, u, v, Case = 0;
while(~scanf("%d %d %d", &n, &m, &k)) {
memset(g, false, sizeof g);
for(int i = 0; i < k; i ++) {
scanf("%d %d", &ui[i], &vi[i]);
g[ui[i]][vi[i]] = true;
}
int res1 = hungary(), cnt = 0;
for(int i = 0; i < k; i ++) {
g[ui[i]][vi[i]] = false;
int res2 = hungary();
if(res2 < res1) cnt ++;
g[ui[i]][vi[i]] = true;
}
printf("Board %d have %d important blanks for %d chessmen.\n", ++ Case, cnt, res1);
}
return 0;
}
*/ #include <cstdio>
#include <cstring>
using namespace std; const int maxn = + ;
int n, m, k;
int linkery[maxn], linkerx[maxn];
bool used[maxn], g[maxn][maxn];
bool flag; bool dfs(int u) {
for(int v = ; v <= m; v ++) {
if(g[u][v] && !used[v]) {
used[v] = true;
if(linkery[v] == - || dfs(linkery[v])) {
if(flag) {
linkery[v] = u;
linkerx[u] = v;
}
return true;
}
}
}
return false;
} int hungary() {
flag = true;
memset(linkery, -, sizeof linkery);
memset(linkerx, -, sizeof linkerx);
int res = ;
for(int i = ; i <= n; i ++) {
memset(used, false, sizeof used);
if(dfs(i)) res ++;
}
return res;
} bool can() {
flag = false;
for(int u = ; u <= n; u ++) {
if(linkerx[u] == -) {
memset(used, false, sizeof used);
if(dfs(u)) return true;
}
}
return false;
} int main() {
int u, v, Case = ;
while(~scanf("%d %d %d", &n, &m, &k)) {
memset(g, false, sizeof g);
for(int i = ; i < k; i ++) {
scanf("%d %d", &u, &v);
g[u][v] = true;
}
int ans = hungary();
int res = , temp;
for(int i = ; i <= n; i ++) {
if(~linkerx[i]) {
temp = linkerx[i];
linkerx[i] = linkery[temp] = -;
g[i][temp] = false;
if(!can()) res ++;
linkerx[i] = temp;
linkery[temp] = i;
g[i][temp] = true;
}
}
printf("Board %d have %d important blanks for %d chessmen.\n", ++ Case, res, ans);
}
return ;
}

hdu-1281.棋盘游戏(二分图匹配 + 二分图关键点查询)的更多相关文章

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

    棋盘游戏 Time Limit: 2000/1000 MS (Java/Others)    Memory Limit: 65536/32768 K (Java/Others)Total Submis ...

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

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

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

    题目链接:http://acm.hdu.edu.cn/showproblem.php?pid=1281 棋盘游戏 Time Limit: 2000/1000 MS (Java/Others)    M ...

  4. hdu 1281 棋盘游戏

    http://acm.hdu.edu.cn/showproblem.php?pid=1281 棋盘游戏 Time Limit: 2000/1000 MS (Java/Others)    Memory ...

  5. HDU——1281 棋盘游戏

    棋盘游戏 Time Limit: 2000/1000 MS (Java/Others)    Memory Limit: 65536/32768 K (Java/Others)Total Submis ...

  6. HDU 1281——棋盘游戏——————【最大匹配、枚举删点、邻接表方式】

     棋盘游戏 Time Limit:1000MS     Memory Limit:32768KB     64bit IO Format:%I64d & %I64u Submit Status ...

  7. (step6.3.5)hdu 1281(棋盘游戏——二分图的完美匹配)

    题目大意:本体是中文题.读者可以直接在OJ上看 解题思路: 1)完美匹配:所有的端点都是匹配点 2)对于二分图的完美匹配,我们需要用一个数组来存储匹配点.(而二分图的其他问题(我们则可以直接使用变量来 ...

  8. hdu 1281 棋盘游戏(二分图)

    题目链接:http://acm.hdu.edu.cn/showproblem.php?pid=1281 每行每列作为节点,给可以放车的点将对应的行列连边,最多可放置的车即为建二分图后的最大匹配,跑一边 ...

  9. HDU 1281 - 棋盘游戏 - [二分图最大匹配]

    题目链接:http://acm.split.hdu.edu.cn/showproblem.php?pid=1281 Time Limit: 2000/1000 MS (Java/Others) Mem ...

随机推荐

  1. linux shell 命令笔记

    标准输入.标准输出.标准错误 File descriptors are integers associated with an opened file or data stream. File des ...

  2. SpringMVC最新教程IDEA版

    1.servlet项目结构与识别 Idea里带个蓝点的文件夹为tomcat吃的网站内容,idea会通过“Web Resource Directory”来标注,会被打成一个war包 这个文件夹里,MET ...

  3. react native之封装离线缓存框架

    请求数据=>本地有无缓存+缓存数据是否过期 =>可用 =>不可用 将代码封装成一个DataStore.js文件, 这里面主要提供:从本地获取数据,从网络获取数据,创建本地时间戳,请求 ...

  4. 【RabbitMQ】Centos7安装RabbitMQ

    介绍 RabbitMQ  是一个在AMQP协议标准基础上完整的,可服用的企业消息系统.它遵循Mozilla Public License开源协议,采用 Erlang 实现的工业级的消息队列(MQ)服务 ...

  5. HDU 1002 A - A + B Problem II (大数问题)

    原题代号:HDU 1002 原题链接:http://acm.hdu.edu.cn/showproblem.php?pid=1002 原题描述: Problem Description I have a ...

  6. Mysql索引深入理解

    一.  引言 Mysql 我们平常用的很多,了解的很多,今天别的不说,直接说mysql的底层是什么,说到底层,就想到数据结构,那么,mysql的数据结构是什么呢? 是B + tree .那么数据库中的 ...

  7. Java数据结构与算法(1):线性表

    线性表是一种简单的数据类型,它是具有相同类型的n个数据元素组成的有限序列.形如如A0,A1,...,An-1.大小为0的表为空表,称Ai后继Ai-1,并称Ai-1前驱Ai. printList打印出表 ...

  8. (实战)多边形,梯形盒阴影css实现技巧

    一般情况下,我们给块状元素(四边形)添加阴影样式,直接用css box-shadow: 0 1px 3px 0 rgba(0, 0, 0, 0.1);就可以了,但是总有一些需求是那么的特别,例如下图: ...

  9. 任何国家都无法限制数字货币。为什么呢? 要想明白这个问题需要具备一点区块链的基础知识: 区块链使用的大致技术包括以下几种: a.点对点网络设计 b.加密技术应用  c.分布式算法的实现 d.数据存储技术 e.拜占庭算法 f.权益证明POW,POS,DPOS 原因一: 点对点网络设计 其中点对点的P2P网络是bittorent ,由于是点对点的网络,没有中心化,因此在全球分布式的网

    任何国家都无法限制数字货币.为什么呢? 要想明白这个问题需要具备一点区块链的基础知识: 区块链使用的大致技术包括以下几种: a.点对点网络设计 b.加密技术应用  c.分布式算法的实现 d.数据存储技 ...

  10. ORACLE DG 库参数db_file_name_convert和log_file_name_convert的作用

    https://www.cnblogs.com/xqzt/p/5089826.html ORACLE DG 库参数db_file_name_convert和log_file_name_convert的 ...