CFCF2194D.Table Cut

普及+/提高

通过率:0%

AC君温馨提醒

该题目为【codeforces】题库的题目,您提交的代码将被提交至codeforces进行远程评测,并由ACGO抓取测评结果后进行展示。由于远程测评的测评机由其他平台提供,我们无法保证该服务的稳定性,若提交后无反应,请等待一段时间后再进行重试。

题目描述

给定一个大小为 n×mn \times m 的表格,其中每个单元格中要么是 00,要么是 11。你的任务是用一条从左上角到右下角的路径将其分为两部分。切割路径只能向右或向下移动。

切割后,令 aa 为表格一部分中 11 的个数,bb 为另一部分中 11 的个数。你的目标是最大化 aba \cdot b 的值。

输入格式

每个测试包含多组测试数据。第一行包含测试用例数量 tt1t1041 \leq t \leq 10^4)。随后是每个测试用例的描述。

每个测试用例第一行为两个整数 nnmm1n,m3×1051 \leq n, m \leq 3 \times 10^52nm3×1052 \leq n \cdot m \leq 3 \times 10^5)——表格的行数和列数。

接下来的 nn 行中,每行有 mm 个整数,第 ii 行第 jj 个数字代表 ai,ja_{i, j}0ai,j10 \leq a_{i, j} \leq 1)。

保证所有测试用例中 nmn \cdot m 的总和不超过 3×1053 \times 10^5

输出格式

对于每个测试用例,输出两行。

第一行输出一个整数,即最大的乘积值。

第二行输出一个由 nn 个字符 'D' 和 mm 个字符 'R' 组成的字符串,表示切割路径的走法,其中 'D' 表示向下走一步,'R' 表示向右走一步。

输入输出样例

  • 输入#1

    3
    5 5
    1 0 1 1 0
    0 1 0 1 1
    1 0 1 0 0
    0 1 0 1 0
    0 0 0 0 1
    5 4
    0 0 1 0
    0 1 1 1
    1 0 0 1
    0 1 0 1
    0 0 1 0
    3 2
    1 0
    0 1
    1 1

    输出#1

    30
    RDRDRDRDDR
    20
    DRRDRDDDR
    4
    DRDRD

说明/提示

下方所示图片为每个测试用例前两组数据的最佳切割,均能获得最大乘积值。

首页