#2605. 寻找子矩阵----cx201304

寻找子矩阵----cx201304

Background

一个由 n 行 m 列构成的矩阵(从上到下对行 1 到 n 编号,从左到右对列 1 到 m 编号),第 i 行第 j 列中有一个正整数 W~ij~。例如下面是一个 3 行 4 列的矩阵。

1 5 2 3
2 3 4 2
8 2 3

现在从中选取一个 p 行 q 列的子矩阵,例如下面黑框中选取的是一个 2 行 3 列的子矩阵。

1 5 2 3
2 3 4 2
8 2 3

仔细观察会发现,从上面的矩阵中选取 2 行 3 列的子矩阵共有 4 种不同的方法。

现在请你找这样一个子矩阵,满足以下条件:

将子矩阵的 q 列从左到右编号为 1 到 ​q​,删除子矩阵中所有编号为奇数的列,或者删除子矩阵中所有编号为偶数的列,然后用子矩阵中剩下的数之和减掉子矩阵中被删除的数之和,得到一个结果 ​S​,S 最大的子矩阵就是我们要找的子矩阵,注意,这样的子矩阵可能有多个。

例如上面黑框中的子矩阵,删除编号为奇数的列(下图 1)或删除编号为偶数的列(下图 2)。(阴影部分为删除的列)

1 5 2 或者 1 5 2
2 3 4 2 3 4

图 1 删除编号为奇数的列 图 2 删除编号为偶数的列

按照计算规则,图 1 中剩下的数之和为 8,被删除的数之和为 9,所以 S=-1,图 2 中剩下的数之和为 9,被删除的数之和为 8,所以 S=1,也就是说当选择这个子矩阵时,S 的最大值为 1。当然可以选择其他子矩阵来获取更大的 ​S​。

Input

共 n+1 行。

第一行包含 4 个整数 n、m、p、q (1≤n,m≤1000,1≤p≤n,1≤q≤m),每两个整数之间用一个空格隔开。

接下来 n 行,每行包含 m 个整数。第 i+1 行的第 j 个整数为 W​~ij~​(1≤W~ij~≤100),表示矩阵中的第 i 行第 j 列的数,每两个整数之间用一个空格隔开。

Output

输出文件 ​matrix.out​:结果输出到文件中。

输出共一行,包含一个整数,表示最大的 S。注意不需要输出……你选择的子矩阵。

Samples

3 4 2 3 
1 5 2 3 
2 3 4 2 
8 2 4 3
13

Limitation

【样例解释】

当选择如下子矩阵时,S 的值为 13,满足最大。

2 3 4
8 2 4

【数据范围约定】对于 30%的数据保证 1≤n≤50,1≤m≤50。

对于 70%的数据保证 1≤n≤300,1≤m≤300。

对于 100%的数据保证 1≤n≤1000,1≤m≤1000。

另外,所有的数据保证 1≤p≤n,1≤q≤m,1≤W~ij~≤100。