#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。