棋盘游戏

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. git-bash下, 启动sshd

    今天发现git-shell下居然有sshd.exe, 尝试了一下,居然起来了.在windiwos下起sshd也是如此简单. #先编辑C:\Program Files (x86)\Git\etc\ssh ...

  2. Kibana后台进程启动和关闭

    原创转载请注明出处:https://www.cnblogs.com/agilestyle/p/12073202.html 后台启动Kibana ./bin/kibana & 查找Kibana进 ...

  3. NOIP模拟赛(by hzwer) T2 小奇的序列

    [题目背景] 小奇总是在数学课上思考奇怪的问题. [问题描述] 给定一个长度为 n 的数列,以及 m 次询问,每次给出三个数 l,r 和 P, 询问 (a[l'] + a[l'+1] + ... + ...

  4. postman—Sandbox和断言

    Postman沙盒 Postman Sandbox是一个JavaScript执行环境,您可以在编写预请求脚本和测试脚本(在Postman和Newman中)时可用.在这个沙箱中执行您在预请求/测试脚本部 ...

  5. PHP生成静态网页的方法

    看到很多朋友在各个地方发帖问PHP生成静态文章系统的方法,以前曾做过这样一个系统,遂谈些看法,以供各位参考.兄弟先带大家回顾一些基本的概念. 一,PHP脚本与动态页面. PHP脚本是一种服务器端脚本程 ...

  6. php大文件下载+断点续传

    如果我们的网站提供文件下载的服务,那么通常我们都希望下载可以断点续传(Resumable Download),也就是说用户可以暂停下载,并在未来的某个时间从暂停处继续下载,而不必重新下载整个文件. 通 ...

  7. php 单示例编程

    <?php defined('SYSPATH') or die('No direct script access.'); class Kohana_BOTA { //私有构造方法,防止再次实例化 ...

  8. string matching

    string matching exkmp #include<bits/stdc++.h> using namespace std; ; int Nex[maxn],extend[maxn ...

  9. 快速获取批量处理Docker镜像SQL语句

    .获取批量pull语句 select concat('docker pull develop-harbor.geostar.com.cn/', t.name, ':', t1.tag) name fr ...

  10. Java的参数传递是值传递?

    引用传递和值传递的区别.(不先说定义的都是在耍流氓!) 按值调用(call by value) : 在参数传递过程中,形参和实参占用了两个完全不同的内存空间.形参所存储的内容是实参存储内容的一份拷贝. ...