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. 静态栈抽象数据类型stack实现

    #include<stdio.h> #include<stdbool.h> #include<stdlib.h> #define MAX_STACK_SIZE 10 ...

  2. nodejs环境变量配置

    步骤 创建文件夹:安装包 配置环境变量: export NODE_HOME=/root/安装包/node-v7.6.0-linux-x64 export PATH=$NODE_HOME/bin:$PA ...

  3. Git的使用规范(一)

    1.建议使用 git add.2.不建议使用git commit -a3.撤销没有add的git checkout . 这个命令我们可以好好的介绍一下,如果当你对文件进行了修改,你没有进行git ad ...

  4. 【转】在Ubuntu 16.10 Server 上部署 Moodle

    第一步 安装 Ubuntu 16.10 Server LTS Moodle 的官方文档肯定了Ubuntu Server LTS 是适合运维Moodle平台的. 1.使用纯代码交互的服务器Ubuntu更 ...

  5. Java:static的作用分析

    static表示“静态”或者“全局”的意思,但在Java中不能在所有类之外定义全局变量,只能通过在一个类中定义公用.静态的变量来实现一个全局变量. 一.静态变量 1. Java中存在两种变量,一种是s ...

  6. 添加用户-查看用户列表-禁止默认root登陆

    程序小屌丝狒狒: (Q971751392) linux添加用户 adduser feifei passwd [用户名] 设置密码 可以查看所有用户的列表 cat /etc/passwd  w 可以查看 ...

  7. Flask 中文手册 0.10 文档

    Flask 中文手册 0.10 文档 欢迎使用 Flask 欢迎阅读 Flask 文档. 本文档分为几个部分.我推荐您先从 安装 开始,之后再浏览 快速入门 章节. 教程 比快速入门更详细地介绍了如何 ...

  8. Java开发WebService(使用Java-WS)

    前言: 初学Java,因为工作需要,直接跳到开发WebService.以前用.NET开发过WebService,对比一下,Java的WebService开发部署难度高了不止一个档次.网上的教程各式各异 ...

  9. 【连载】Bootstrap开发漂亮的前端界面之自定义右键菜单

    连载: 1<教你用Bootstrap开发漂亮的前端界面> 2.<Bootstrap开发漂亮的前端界面之实现原理> 网页中的自定义右键菜单越来越普遍,自定义右键菜单可以增强用户体 ...

  10. python接口测试(二)——配置文件的使用

    在接口测试中,有些东西是固定不变的,比如url,若想更改的话就必须每个请求都更改,因此,可以放到配置文件中使用. 1.创建一个.ini的配置文件,如图: 2.读取配件文件中的内容,后续进行引用 #co ...