问题描述:
在一个有m*n 个方格的棋盘中,每个方格中有一个正整数。现要从方格中取数,使任
意2 个数所在方格没有公共边,且取出的数的总和最大。试设计一个满足要求的取数算法。编程任务:
对于给定的方格棋盘,按照取数要求编程找出总和最大的数。
数据输入:
由文件input.txt提供输入数据。文件第1 行有2 个正整数m和n,分别表示棋盘的行数
和列数。接下来的m行,每行有n个正整数,表示棋盘方格中的数。
结果输出:
程序运行结束时,将取数的最大总和输出到文件output.txt中。
输入示例 输出示例
3 3 11
1 2 3
3 2 3
在一个有m*n 个方格的棋盘中,每个方格中有一个正整数。现要从方格中取数,使任
意2 个数所在方格没有公共边,且取出的数的总和最大。试设计一个满足要求的取数算法。编程任务:
对于给定的方格棋盘,按照取数要求编程找出总和最大的数。
数据输入:
由文件input.txt提供输入数据。文件第1 行有2 个正整数m和n,分别表示棋盘的行数
和列数。接下来的m行,每行有n个正整数,表示棋盘方格中的数。
结果输出:
程序运行结束时,将取数的最大总和输出到文件output.txt中。
输入示例 输出示例
3 3 11
1 2 3
3 2 3
2 3 1
分析:
二分图最大点权独立集问题。最大独立集和最小覆盖数是互补的。所以这题就转化为了求最小点权覆盖集。最小点权覆盖集就是最小简单割,最小割又可以用网络流解。
故,最大点权独立集 = 所有点权 - 最小点权覆盖集 = 所有点权 - 最小割集 = 所有点权 - 网络最大流。
建模方法也简单,就是染色使所有相邻的点颜色不一样,两种颜色对应二分图XY顶点,然后所有X顶点若和Y顶点相邻,则加一条无穷容量的边,S向所有X顶点加容量为点权的边,所有Y顶点向T点加容量为点权的边。然后求一次最大流即可。这题和02题比较相似。
这题思想很简单没什么变化的地方,所以代码也不需要什么注释了吧。