Description

在一个有m*n 个方格的棋盘中,每个方格中有一个正整数。现要从方格中取数,使任意2 个数所在方格没有公共边,且取出的数的总和最大。试设计一个满足要求的取数算法。

编程任务:
对于给定的方格棋盘,按照取数要求编程找出总和最大的数。

Input

第1 行有2 个正整数m和n,分别表示棋盘的行数和列数。
接下来的m行,每行有n个正整数,表示棋盘方格中的数。

Output

程序运行结束时,将取数的最大总和输出

Sample Input

3 3
1 2 3
3 2 3
2 3 1

Sample Output

11

 

就是找一些点,使得互不相连,并且点权和最大。

结论是

  先黑白染色一次。

  S向所有黑点连一条为该权值的边,所有白点向T连一条为该权值的边。

  黑点向周围四个白点连无限流量的边。

  转化为了一张图,ans=所有点权和-最小割。

证明是

  其实我认为有最大闭合权图思想,就是说,最小割=简单割,很显然吧。

  将左边的边割去,表示这些黑点不选,右边的边割去,表示这些白点不选,

  那么,最小割保证不连通,所以保证了这些点互不相连。

  所以所以点权和-最小割=最优解。