#L3500. 「联合省选 2021 A」矩阵游戏

「联合省选 2021 A」矩阵游戏

「联合省选 2021 A」矩阵游戏

题目描述

Alice 有一个 n×mn \times m 的矩阵 ai,ja_{i, j}1in1 \le i \le n1jm1 \le j \le m),其每个元素为大小不超过 10610^6 的非负整数。

Bob 根据该矩阵生成了一个 (n1)×(m1)(n - 1) \times (m - 1) 的矩阵 bi,jb_{i, j}1in11 \le i \le n - 11jm11 \le j \le m - 1),每个元素的生成公式为

$$b_{i, j} = a_{i, j} + a_{i, j + 1} + a_{i + 1, j} + a_{i + 1, j + 1} $$

现在 Alice 忘记了矩阵 ai,ja_{i, j},请你根据 Bob 给出的矩阵 bi,jb_{i, j} 还原出 ai,ja_{i, j}

输入格式

本题有多组数据。

第一行,一个整数 TT,表示数据组数。对于每组数据:

第一行,两个正整数 n,mn, m,表示矩阵 ai,ja_{i, j} 的大小。 接下来 n1n - 1 行,每行 m1m - 1 个非负整数,表示 bi,jb_{i, j}

输出格式

对于每组数据:

  • 若矩阵 bi,jb_{i, j} 无法被生成,则输出一行一个字符串 NO
  • 若矩阵 bi,jb_{i, j} 可被生成,则先输出一行一个字符串 YES,接下来输出 nn 行每行 mm 个(用单个空格分隔的)大小不超过 10610^6 的非负整数表示 ai,ja_{i, j}
  • 若有多个矩阵 ai,ja_{i, j} 可生成给出的 bi,jb_{i, j},输出其中任意一个即可。

样例

输入

3
3 3
28 25
24 25
3 3
15 14
14 12
3 3
0 3000005
0 0

输出

YES
7 8 8
8 5 4
4 7 9
YES
4 2 2
5 4 6
5 0 2
NO

数据范围与提示

对于所有测试数据:

  • 1T101 \le T \le 10
  • 2n,m3002 \le n, m \le 300
  • 0bi,j4×1060 \le b_{i, j} \le 4 \times 10^6

每个测试点的具体限制见下表:

测试点编号 n,mn, m \le 特殊限制
1 ~ 4 3
5 ~ 7 10 m=2m = 2
8 ~ 10 100
11 ~ 15 300 0bi,j10 \le b_{i, j} \le 1
16 ~ 20