骑士放置
给定一个 N*M 的棋盘,有一些格子禁止放棋子。
问棋盘上最多能放多少个不能互相攻击的骑士(国际象棋的“骑士”,类似于中国象棋的“马”,按照“日”字攻击,但没有中国象棋“别马腿”的规则)。
输入格式
第一行包含三个整数N,M,T,其中T表示禁止放置的格子的数量。
接下来T行每行包含两个整数x和y,表示位于第x行第y列的格子禁止放置,行列数从1开始。
输出格式
输出一个整数表示结果。
数据范围
1 ≤ N , M ≤ 100 1≤N,M≤100 1≤N,M≤100
输入样例:
2 3 0
输出样例:
4
题解:
我们还是通过奇偶染色来看,奇数染黑(在自己草稿本上花下)可以发现我当前格子的横纵坐标为偶数的时候,攻击的位置一定是黑色的。所以我们这个图是满足二分图的。(未证明,经验做题)。所以我们在能攻击到的地方连一条边,那么题目要求不能互相攻击,并且要求摆放的棋子尽可能多。所以这明显就是一个最大独立集的问题了。那么答案就是总的格子数-坏掉的格子数目-最大匹配(最小点覆盖)。
#include <bits/stdc++.h>
using namespace std;
typedef pair<int,int> pii;
const int N=1e2+7;
int ne[N],head[N],