CF2194D Table Cut

题目描述

给定一个大小为 $n \times m$ 的表格,其中每个单元格中要么是 $0$,要么是 $1$。你的任务是用一条从左上角到右下角的路径将其分为两部分。切割路径只能向右或向下移动。 切割后,令 $a$ 为表格一部分中 $1$ 的个数,$b$ 为另一部分中 $1$ 的个数。你的目标是最大化 $a \cdot b$ 的值。

输入格式

每个测试包含多组测试数据。第一行包含测试用例数量 $t$($1 \leq t \leq 10^4$)。随后是每个测试用例的描述。 每个测试用例第一行为两个整数 $n$ 和 $m$($1 \leq n, m \leq 3 \times 10^5$,$2 \leq n \cdot m \leq 3 \times 10^5$)——表格的行数和列数。 接下来的 $n$ 行中,每行有 $m$ 个整数,第 $i$ 行第 $j$ 个数字代表 $a_{i, j}$($0 \leq a_{i, j} \leq 1$)。 保证所有测试用例中 $n \cdot m$ 的总和不超过 $3 \times 10^5$。

输出格式

对于每个测试用例,输出两行。 第一行输出一个整数,即最大的乘积值。 第二行输出一个由 $n$ 个字符 'D' 和 $m$ 个字符 'R' 组成的字符串,表示切割路径的走法,其中 'D' 表示向下走一步,'R' 表示向右走一步。

说明/提示

下方所示图片为每个测试用例前两组数据的最佳切割,均能获得最大乘积值。 ![](https://cdn.luogu.com.cn/upload/vjudge_pic/CF2194D/68507944970a46e40e4f5d7e2865b75baa1b3ac59d1215c06cd6f419ddbe860b.png) ![](https://cdn.luogu.com.cn/upload/vjudge_pic/CF2194D/8c42600d149c381fa5519e8bdabe7d1b0aded40a7b7bbcedc8ff50df4f9821b1.png) 由 ChatGPT 5 翻译