题目解析
原型题:P4251 [SCOI2015] 小凸玩矩阵 - 洛谷
本题需要我们从矩阵中选取N个元素,这个N元素的特点是:任意两个不能同行同列。
而满足上面条件的N个元素存在多组,我们需要找到着各个组中第K大元素的最小值。
难点一:如何从矩阵中找到N个互相不同行同列的元素呢?
暴力枚举的话,肯定会超时,因此需要寻找更优解法。
根据要求,每行每列只能有一个元素被选择,即可以认为每个行号只能和一个列号进行配对,且配对过的列号不能再和其他行号配对,而形成了配对关系的行号,列号,其实就是一个元素的坐标位置。
因此,找N个互相不同行同列的元素,其实就是在二分图(所有行号一部分,所有列号一部分)找N个边的匹配。
如下图所示
关于二分