AT_rco_contest_2017_final_b 日本橋大渋滞

题目描述

给你一个有 $H$ 行 $W$ 列的网格地图(类似于围棋棋盘的格子,每个格子有一个坐标),其中有 $K$ 辆车。 最上面一行是第 $1$ 行,最左边一列是第一列,$r$ 行 $c$ 列的格子表示为 $(r,c)$。 每辆车有一个初始位置 $(A_i,B_i)$ 和一个目标位置 $(C_i,D_i)$。在每一个时刻 $t$ 可以让每辆车移动到相邻的格子里或者不动(被移动的车会在 $t+1$ 时刻完成移动)。 以下情况不能移动: - 在 $t$ 时刻时想要移动的格子有车; - 多辆车同时移动到同一个格子; - 移动到了规定的地图大小之外。 你最多能发出 $T$ 个指令。 你要书写程序使得得分最大。得分计算规则如下: 若最终位置为 $(r_i, c_i)$ $$P_D=20+\sum\limits_{i=1}^K(|r_i-C_i|+|c_i+D_i|)$$ $P_T=10+L \times 0.01$($0 \leq L

输入格式

输入的数都是整数。 输出共 $1+K$ 行。 第一行输入 $ H $、$ W $、$ K $、$ T $,分别表示图中的行数、地图列数、地图上车辆数量和能给车的指示次数的最大值。 接下来 $K$ 行,每行输入 $4$ 个目的格。

输出格式

第一行输出需要的指令数量 $L$; 在下面 $L$ 行上,输出表示在时间 $t$ 发送给每辆车的指令的字符串。 指令字符串由 $K$ 个字母组成,每个字符串的第 $i$ 个字母表示在这个时刻第 $i$ 辆车的行动。 `R` 表示向右 `L` 表示向左 `U` 表示向上 `D` 表示向下 `-` 表示不动

说明/提示

### テストケースの生成について 各テストケースは次の手順で生成されます。 - 初期マスの候補となる$ K $個のマスを、$ H\ \times\ W $個のマスの中から、重複しないようにランダムに選ぶ。 - それらの初期マスの候補を、ランダムに $ K $ 台の車に割り当てる。 - 目的マスの候補となる$ K $個のマスを、$ H\ \times\ W $個のマスの中から、重複しないようにランダムに選ぶ。 - それらの目的マスの候補を、ランダムに $ K $ 台の車に割り当てる。 ### ジェネレータとテスター ジェネレータとテスターを次のリンクから提供しています。 [ジェネレータ・テスター](https://gist.github.com/tomerun/00a0efb3b1d738494791e05ebf18c3d5) ### ビジュアライザ 入力ファイルと出力ファイルから、得点の計算および結果を可視化するビジュアライザを用意しました。 - このビジュアライザは主要なブラウザ上で動作確認を行っていますが、全ての環境で動作することを保証していません。 - このビジュアライザ上で計算された得点は、当コンテストでの得点ではありません。解答を AtCoder 上で提出する事によって採点が行われます。また、ビジュアライザ上で計算された得点は、当コンテスト上での得点を保証するものではありません。 - このビジュアライザを使用することによるあらゆる損害は保障しかねますので、予めご了承ください。 ビジュアライザは次のリンクからも提供しています。使用法についてもリンク先に記述があります。 [ビジュアライザ](https://gist.github.com/tomerun/8fc27d5cce6408032336fd316d817a7c) ### Sample Explanation 1 注意: この入力はテストケースとしての制約を満たしていません。 車1の初期マスを $ 1 $、車1の目的マスを $ X $、車2の初期マスを $ 2 $、車2の目的マスを $ Y $ としたマップを以下に図示します。 !\[\]() 全ての指示を実行後のマップは以下のようになります。車1は目的マスに到着しています。 !\[\]() - 時刻 $ 0 $ では車1も車2も右に移動します。 - 時刻 $ 1 $ では車1は右に、車2は上に移動します。 - 時刻 $ 2 $ では車1は下に、車2は上に移動します。 - 時刻 $ 3 $ では車1は移動しません。車2は左に移動します。 - この出力によって得られるスコアは、以下のように計算されます。 - 車1の目的マスは $ (4,5) $ で、最終的な位置は $ (4,5) $ です。 - 車2の目的マスは $ (2,4) $ で、最終的な位置は $ (4,2) $ です。 - よって $ P_D $ は $ 20+\ (|4-4|+|5-5|)+(|2-4|+|4-2|)=24 $ です。 - $ P_T $ は $ 10\ +\ 4\ \times\ 0.01=10.04 $ です。 - このテストケースでの得点は $ 10^7\ /\ (24\ \times\ 10.04)\ =\ 41500.6… $ を切り上げた $ 41501 $ となります。 ### Sample Explanation 2 ジェネレータに $ seed=1 $ を指定することで同じ入力が得られます。