Problem Description

给定一个n * m的棋盘,在棋盘里放尽量多的国际象棋中的车,使他们不能相互攻击 已知有些格子不能放置,问最多能放置多少个车 并计算出必须棋盘上的必须点。

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.

思路:对于第一个问题 可以把行、列看做二分图的左右节点,共n + m个节点  对所有可放置车的坐标(x, y) 把x,y连边 然后放一个车相当于将x, y两节点匹配 然后就可以用二分图最大匹配来做了

对于第二个问题,暴力枚举所有(x,y),并将其挖掉,如果匹配数减少了,(x,y)就是必须点。

#include<iostream>
#include<cstdio>
#include<cstring>
using namespace std;
const int N = ;
int n, m, q, mat[];
bool vis[], f[][]; int head[],now;
struct edges{
int to,next;
}edge[N<<];
void add(int u,int v){ edge[++now] = {v,head[u]}; head[u] = now;} struct input{
int x,y;
}inp[N];
void init(){
memset(edge,,sizeof(edge));
memset(head,,sizeof(head)); now = ;
memset(mat,,sizeof(mat));
} bool dfs(int x){
for(int i = head[x]; i; i = edge[i].next){
int v = edge[i].to;
if(!vis[v] && !f[x][v]){
vis[v] = ;
if(!mat[v] || dfs(mat[v])){
mat[v] = x;
return ;
}
}
}
return ;
} int main(){
// freopen("data.in","r",stdin);
ios::sync_with_stdio(false);
int kase = ;
while(cin>>n>>m>>q){
init();
int x,y;
for(int i = ; i <= q; i++){
cin>>x>>y; y += n;
inp[i] = {x, y};
add(x,y);// add(y,x);
}
int ans = ;
for(int i = ; i <= n; i++){
memset(vis,,sizeof(vis));
if(dfs(i)) ans++;
}
int tot = ;
for(int i = ; i <= q; i++){
f[inp[i].x][inp[i].y] = f[inp[i].y][inp[i].x] = ; //枚举每个可放置的点
memset(mat,,sizeof(mat));
int cnt = ; //cnt记录每次挖去一个点后的匹配数
for(int j = ; j <= n; j++){
memset(vis,,sizeof(vis));
if(dfs(j)) cnt++;
}
if(cnt < ans) tot++;
f[inp[i].x][inp[i].y] = ;
}
printf("Board %d have %d important blanks for %d chessmen.\n",++kase,tot,ans);
}
return ;
}

  

hdu1281(棋盘游戏,车的放置)的更多相关文章

  1. HDU1281 棋盘游戏 —— 二分图最大匹配 + 枚举

    题目链接:https://vjudge.net/problem/HDU-1281 棋盘游戏 Time Limit: 2000/1000 MS (Java/Others)    Memory Limit ...

  2. hdu-1281.棋盘游戏(二分图匹配 + 二分图关键点查询)

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

  3. P1350 车的放置

    P1350 车的放置 设$f[i][j]$为当前推到第$i$列,该列高度$h$,已经放了$j$个车的方案数 则$f[i][j]=f[i-1][j]+f[i-1][j-1]*(h-j+1)$ 但是我们发 ...

  4. 洛谷 P1350 车的放置

    洛谷 P1350 车的放置 题目描述 有下面这样的一个网格棋盘,a,b,c,d表示了对应边长度,也就是对应格子数. 当a=b=c=d=2时,对应下面这样一个棋盘 要在这个棋盘上放K个相互不攻击的车,也 ...

  5. Hdu1281 棋盘游戏

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

  6. hdu------1281 棋盘游戏(最小覆盖点)

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

  7. 【CH6802】车的放置

    题目大意:给定一个 N*M 的棋盘,棋盘上有些点不能放置任何东西,现在在棋盘上放置一些车,问最多可以放置多少个车而不会互相攻击. 题解:将放置一个车看作连接一条无向边,因为每一行和每一列之间只能放置一 ...

  8. 【题解】洛谷P1350 车的放置(矩阵公式推导)

    洛谷P1350:https://www.luogu.org/problemnew/show/P1350 思路 把矩阵分为上下两块N与M 放在N中的有i辆车 则放在M中有k-i辆车 N的长为a   宽为 ...

  9. 【u022】车的放置

    [问题描述] [题解] 先考虑一个最简单的情况.如一个n*n的棋盘.然后要放k个车. 我们可以先选出k行即C(n,k); 然后在列上对这k个棋子进行一次全排列即A(n,k); 比如k = 4;N=5 ...

随机推荐

  1. Git----使用WebHook实现代码自动部署

    起因: 经常本地push到gitee等线上代码仓库,然后登陆服务器在进行pull,很麻烦,想偷懒怎么办?使用git的webhook实现! 1.实现原理 1.1本地提交推送 1.2线上仓库监听push动 ...

  2. Java HotSpot(TM) 64-Bit Server VM warning: INFO: os::commit_memory(0x0000000

    启动程序报错: Java HotSpot(TM) 64-Bit Server VM warning: INFO: os::commit_memory(0x00000006fff80000, 28636 ...

  3. Andrew Ng Machine Learning Coursera学习笔记

    课程记录笔记如下: 1.目前ML的应用 包括:数据挖掘database mining.邮件过滤email anti-spam.机器人autonomous robotics.计算生物学computati ...

  4. Android面试收集录 OpenGL ES

    1.如何用OpenGL ES绘制一个三角形? 编写一个类实现Renderer接口,实现onDrawFrame方法,onSurfaceChanged方法,onSurfaceCreated方法 编写一个类 ...

  5. C++11中std::bind的使用

    std::bind: Each argument may either be bound to a value or be a placeholder: (1).If bound to a value ...

  6. bootstrap重新设计checkbox样式

    文章采集于: https://www.cnblogs.com/GumpYan/p/7845445.html#undefined 在原文基础上修改了勾勾的内容,直接采用bootstrap字体库.修改了横 ...

  7. P2966 [USACO09DEC]牛收费路径Cow Toll Paths

    P2966 [USACO09DEC]牛收费路径Cow Toll Paths 题目描述 Like everyone else, FJ is always thinking up ways to incr ...

  8. Apache 服务器性能评估

    1 查看当前并发连接数 netstat -an | grep ESTABLISHED | wc -l 2 查看当前进程数 ps aux|grep httpd|wc -l

  9. jdk带的一些工具,强悍

    这些工具有的已经接触到了,功能很强悍,但是使用也有点复杂(参数) 在代码中使用System.setProperty()或者在启动程序时使用-D选项设置代理服务器地址和端口 看看别人的研究: JDK自带 ...

  10. 【紫书】(UVa1347)Tour

    继续考虑dp题目. 题意分析 其实这里只是更加仔细的做一个lrj的复读机(Orz 他分析了一个很重要的结果:如果是一个人从左到右再回来,并且每个点恰经过一次,那么等价于两个人从左到右每个点经过一次地遍 ...