/ Vijos / 题库 /

建房子

建房子

背景

安得广厦千万间,天下寒士俱欢颜。

描述

小D终于成为了一位建筑师。他的第一个任务是在一块n行m列的矩形土地上砌房子,每个房子的大小是a行b列(不能旋转)。

矩形土地的每个单元格都有一个高度。如果选定某个区域上为建房子的地方,那么需要将这个区域的每个单元格的高度变成这个区域的最小的单元格的高度,因为这样能使土地更平整。将一个单元格的高度从h2变为h1所花费的代价是h2-h1,一个区域所花费的代价为其每个单元格所花费的代价之和。

现在小D按下面所述的方式建房子:
1、首先找到矩形土地中花费最少代价就能建房子的区域(这个区域中不能有某个单元格已经砌了房子),如果有多个这样的区域,选择左上角所在行尽可能小的,如果行相同,选择列尽可能小的。

2、接下来在这块区域砌一栋房子。

3、重复上述操作,直到找不到一个可以砌房子的区域。

现在需要你告诉小D,他一共将砌多少栋房子,每栋房子的左上角的坐标,以及每栋房子所花费的代价。

格式

输入格式

输入的第一行包括四个正整数
n,m,a,b(含义如上所述)
接下来n行,每行m个非负整数
其中第i行,第j列表示第i行,第j列的单元格的高度。

输出格式

输出第一行为一个非负整数S:表示一共砌了多少栋房子
接下来S行
每行三个整数i,j,v:表示第S个房子的左上角的所在行,所在列,以及所花费的代价。

样例1

样例输入1

3 2 1 2
2 5
1 2
3 5

样例输出1

3
2 1 1
3 1 2
1 1 3

样例2

样例输入2

5 5 2 2
9 9 4 4 10 
10 3 3 9 3 
3 6 3 8 1 
4 2 10 9 8 
7 10 10 3 5 

样例输出2

4
2 2 3
4 4 13
1 4 14
4 1 15

限制

每个测试点2s

提示

30%保证:n <= 10, m <= 10
70%保证:n <= 300, m <= 300
100%保证:n <= 1000, m <= 1000
1<= a <= n, 1 <= b <= m, 每个单元格的高度 <= 10^9

来源

codeforces

信息

ID
1750
难度
8
分类
数据结构 | 单调队列 点击显示
标签
(无)
递交数
401
已通过
54
通过率
13%
被复制
1
上传者

相关

在下列训练计划中:

RP++分类题库

在下列比赛中:

NOIP2012模拟赛