编程介的小学生 2017-08-30 12:40 采纳率: 20.5%
浏览 724
已采纳

Coverage

Consider the following situation. Each grid point in an infinite two-dimention plane is assigned an integer value. All values except a very special group of points lying in a matrix of N * M are ZERO. The values in the matrix will be given.

Now you have a board of rectangle of size H * W. Cut the board into two rectangles. Assume that their sizes are a1 * b1 and a2 * b2 (These four numbers should all be positive integers). We can use them to cover a matrix of a1 * b1 and a matrix of a2 * b2. You are to maximize the sum of all the values in the two matrices.

Note: The board CANNOT rotate but the two matrices can overlap(Values in both matrices are counted twice).

Input

There are no more than 30 cases. Proceed till the end of file.
The first line of each case is four integers N, M, H, W (2 <= H <= N <= 100, 2 <= W <= M <= 100).
Then follows N lines each of M integers indicating the values in the special matrix. Integers are in range [-10000, 10000].

Output

For each case print the max sum.

Sample Input

3 4 3 2
-1 1 -1 -1
-1 1 -1 -1
-1 1 -1 -1
Sample Output

6

  • 写回答

1条回答 默认 最新

报告相同问题?

悬赏问题

  • ¥15 c程序不知道为什么得不到结果
  • ¥40 复杂的限制性的商函数处理
  • ¥15 程序不包含适用于入口点的静态Main方法
  • ¥15 素材场景中光线烘焙后灯光失效
  • ¥15 请教一下各位,为什么我这个没有实现模拟点击
  • ¥15 执行 virtuoso 命令后,界面没有,cadence 启动不起来
  • ¥50 comfyui下连接animatediff节点生成视频质量非常差的原因
  • ¥20 有关区间dp的问题求解
  • ¥15 多电路系统共用电源的串扰问题
  • ¥15 slam rangenet++配置