题目大意:一个矩阵,一些点被拿掉,在棋盘上马走日,马之间不能落在同一点,求最多放几匹马. 采用对矩阵黑白染色,画个图可以发现:马可以走到的位置和他所处的位置颜色不同,将马和他可以走到的位置连边,最多可以放多少马,相当于求图的最大独立集(任意一条边的两个端点不会同时被选中). 用黑白染色将节点按颜色分成两类,就是一个二分图. 题解代码: 1 #include<bits/stdc++.h> 2 using namespace std; 3 #define maxn 40000 4 struct e…