CFCF2155B.Abraham's Great Escape

普及-

通过率:0%

AC君温馨提醒

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

题目描述

Abraham 是一位勇敢的探险家,他踏足了其他程序员从未到达的地方。在他的下一次探险中,他计划调查一个奇特的迷宫。他知道迷宫是一个 n×nn \times n 的方格,每个单元格中都有一支箭头,指向四个方向中的一个:上、下、左、右。Abraham 还知道,如果他站在一个箭头上,他将被迫从该单元格开始沿箭头前进。每一次箭头都会让 Abraham 沿其所指的方向恰好移动 11 个单元格。如果他到达了一个指向迷宫外侧的箭头,Abraham 就能逃出迷宫。

Abraham 并不知道箭头的具体布局,所以他想要规划多种情形。他让你在这个方格中设计一种箭头的排布,使得恰好有 kk 个起始单元格能够让他逃出迷宫。

输入格式

每个测试点包含多个测试用例。第一行包含测试用例数量 tt1t10001 \le t \le 1000)。接下来的每个测试用例包含一行两个整数 nnkk2n1002 \le n \le 1000kn20 \le k \le n^2)——网格的大小,以及 Abraham 应该能够逃出的起始单元格的数量。

保证所有测试用例的 n2n^2 之和不超过 10510^5

输出格式

对于每个测试用例,进行如下输出:

  • 如果存在满足要求的箭头排列,输出 YES,并输出 nn 行,每行 nn 个字符,表示每个格子的箭头方向。每个字符应为 U(上)、R(右)、L(左)或 D(下)。
  • 否则,输出 NO,表示无法完成任务。

如果有多种方案,输出任意一种均可。

输出可以采用任意大小写,例如 "yEs"、"yes"、"Yes" 或 "YES" 都被认为是肯定的回答。

输入输出样例

  • 输入#1

    3
    2 4
    3 5
    2 3

    输出#1

    YES
    UU
    UU
    YES
    UUU
    RDR
    ULR
    NO

说明/提示

在第一个测试用例中,无论 Abraham 最初站在哪个单元格,他最终都会不断向上移动并逃出迷宫,因此他可以从所有 44 个格子逃出,如题目要求。

在第二个测试用例中,Abraham 如果最初位于以下位置最终可以逃出:

  • 第一行的任意单元格(全部为 U)
  • 第三列的任意单元格(其中一个为 U,另外两个为 R)

不存在其他可以使他逃出的起始格子。由此 Abraham 恰好可以从 55 个格子逃出,满足要求。

在第三个测试用例中,可以证明不存在一种箭头排列,使 Abraham 恰好可以从 33 个格子逃出。

首页