AT_ahc036_a [AHC036A] Efficient Signal Control

Description

[problemUrl]: https://atcoder.jp/contests/ahc036/tasks/ahc036_a Y国には $ N $ 個の都市と $ M $ 本の道路があり、$ i $ 番目の道路は都市 $ u_i $ と都市 $ v_i $ を双方向に結んでいる。どの道路も交差はなく、都市と道路からなるグラフは平面グラフである。 各都市には、その都市へと入る交通を制御するための**信号**がある。 信号には**赤**または**青**の $ 2 $ つの状態があり、都市 $ v $ の信号が青である場合のみ、都市 $ v $ へと移動できる。(移動元の都市の信号はどちらでも良い) Y国の都市の信号は、配列 $ A,\ B $ によって一元管理されている。 配列 $ A $ は長さ $ L_A $ であり、各要素は $ 0 $ 以上 $ N-1 $ 以下の整数である。 配列 $ B $ は長さ $ L_B $ であり、初期状態は、すべての要素が $ -1 $ である。 特に、配列 $ B $ は信号の状態を表す配列であり、配列 $ B $ が値 $ v $ を要素として含むとき、都市 $ v $ の信号は青である。配列 $ B $ が値 $ v $ を要素として含まないとき、都市 $ v $ の信号は赤である。 配列 $ A $ は、配列 $ B $ の制御に用いる配列であり、以下のように操作することで配列 $ A $ の値を用いて配列 $ B $ の内容を変更し、信号の状態を変化させることが出来る。 1. $ A $ から連続する領域を選び、その領域を $ R_A $ とする。 2. $ B $ から、$ R_A $ と同じ長さの連続する領域を選び、その領域を $ R_B $ とする。 3. $ R_B $ の内容を、$ R_A $ の内容で上書きする。 さて、旅行好きなXは、Y国を旅行する計画を立てている。 Xは旅行計画として、都市の頂点番号のリスト $ t_0,\ t_1,\ \ldots,\ t_{T-1} $ を持っており、これらの都市を順に訪問したいと考えている。リストの中には同じ都市が複数回含まれる場合もあるが、同じ都市が連続して含まれることはない。 Xは都市 $ 0 $ を現在位置として、旅を始める。まず初めに、Xは友人であるY国の交通大臣に依頼し、信号の制御に用いる配列 $ A $ の内容を好きな値に設定する。 これ以降、$ A $ の内容を変更することはできない。 その後、次の **信号操作** または **移動** を好きな順序で $ 10^5 $ 回以下の好きな回数繰り返す。信号操作と移動の具体例については下部の「出力例」セクションも参照せよ。 - 信号操作 - Y国の交通大臣に依頼し、上述した信号に対する操作を 1 回行い、信号の状態を変化させる。 - 移動 - Xの現在位置である都市から直接道路でつながっている都市の 1 つに移動し、現在位置を移動先の都市に更新する。移動先の都市の信号は青である必要がある。 旅行計画にある都市すべてをリストの順序で訪れることができた場合、Xの旅行は成功となる。 より厳密には、Xの現在位置となった都市を順に $ c_0\ =\ 0,\ c_1,\ \ldots $ としたとき、ある狭義単調増加な長さ $ T $ の非負整数列 $ (i_0,\ i_1,\ \ldots,\ i_{T-1}) $ であって $ c_{i_j}\ =\ t_j(0\ \le\ j\ \le\ T\ -\ 1) $ であるようなものが存在する場合、またその場合に限り、Xの旅行は成功となる。 Y国の交通大臣は非常に多忙なため、Xは信号操作の回数をなるべく減らしたいと考えている。 配列 $ A $ の要素の決定と信号操作・移動をうまく行い、できるだけ少ない信号操作の回数で旅を成功させてほしい。

Input Format

入力は以下の形式で標準入力から与えられる。 ``` \( N ~ M ~ T ~ L_A ~ L_B \\ u_0 ~ v_0 \\ \vdots \\ u_{M-1} ~ v_{M-1} \\ t_{0} ~ t_{1} ~ \ldots ~ t_{T-1} \\ x_0 ~ y_0 \\ \vdots \\ x_{N-1} ~ y_{N-1} \) ``` - 1行目には5つの整数 $ N,M,T,L_A,L_B $ がスペース区切りで与えられる。 - $ N $ は都市の数で、$ N\ =\ 600 $ を満たす。 - $ M $ は道路の本数で、$ N-1\ \le\ M\ \le\ 3\ \times\ N-6 $ を満たす。 - $ T $ は訪問する都市の数で、$ T\ =\ 600 $ を満たす。 - $ L_A $ は信号の制御に用いる配列 $ A $ の長さで、$ N\ \le\ L_A\ \le\ 2\ \times\ N $ を満たす。 - $ L_B $ は信号の制御に用いる配列 $ B $ の長さで、$ 4\ \le\ L_B\ \le\ 24 $ を満たす。 - 続く $ M $ 行は道路の情報で、道路 $ i $ は 都市 $ u_i $ と $ v_i $ を双方向に結ぶ。 $ u_i,\ v_i $ は、$ 0\ \le\ u_i\ \lt\ v_i\ \le\ N\ -\ 1 $, $ (u_i,\ v_i)\ \neq\ (u_j,\ v_j)\ (i\ \neq\ j) $ を満たす。 - 次く1行に、$ T $ 個の整数値がスペース区切りで与えられる。$ t_0,\ t_1,\ ...,\ t_{T\ -\ 1} $ は、Xが訪れる予定の都市であり、 $ 0\ \le\ t_i\ \le\ N\ -\ 1\ (0\ \le\ i\ \le\ T\ -\ 1) $, $ t_0\ \neq\ 0 $, $ t_i\ \neq\ t_{i+1}\ (0\ \le\ i\ \le\ T\ -\ 2) $ を満たす。 - 続く $ N $ 行は、ビジュアライザのため、都市 $ i $ の座標が $ (x_i,\ y_i) $ として与えられる。座標の値は整数であり、 $ 0\ \le\ x_i,\ y_i\ \le\ 1000 $, $ (x_i,\ y_i)\ \neq\ (x_j,\ y_j)\ (i\ \neq\ j) $ を満たす。不要であれば読み込まなくても構わない。 与えられるグラフは、連結な平面グラフであり、頂点 $ i $ を座標 $ (x_i,\ y_i) $ に配置し、各辺を両端点を結ぶ線分として描画した時、どの二辺も端点以外に共通点を持たないことが保証されている。 ### 出力 1行目に、$ A $ の初期値を表す $ L_A $ 個の $ 0 $ 以上 $ N\ -\ 1 $ 以下の整数をスペース区切りで出力せよ。 続く各行に、以下のフォーマットで行動を出力せよ。 - 信号操作を行う場合 $ R_A,\ R_B $ の長さを $ l\ (1\ \le\ l\ \le\ L_B) $、 $ R_A $ の開始位置を $ P_A\ (0\ \le\ P_A\ \le\ L_A\ -\ l) $、 $ R_B $ の開始位置を $ P_B\ (0\ \le\ P_B\ \le\ L_B\ -\ l) $ としたとき、以下のように、行頭の `s` に続けてスペース区切りで $ l,\ P_A,\ P_B $ を出力せよ。 > s $ l P_A P_B $ - 移動を行う場合 移動先の都市の番号を $ v $ としたとき、 以下のように、行頭の `m` に続けてスペース区切りで $ v $ を出力せよ。 > m $ v $ 移動先の都市は現在の都市と直接道路で繋がっており、信号はこの時点で青である必要があることに注意せよ。 [例を見る](https://img.atcoder.jp/ahc036/e5f02df53f30d36e.html?lang=ja&output=sample)

Output Format

N/A

Explanation/Hint

### 得点 旅行が成功したときの信号操作の回数が $ C $ のとき、$ C $ の絶対スコアが得られる。絶対スコアは小さければ小さいほどよい。 旅行が成功しなかった場合、不正な信号操作/移動を行った場合、信号操作と移動を行った回数が $ 10^5 $ 回を超えた場合は WA と判定される。 各テストケース毎に、 \\( \\text{round}(10^9 \\times \\left(\\frac{全参加者中の最小絶対スコア}{自身の絶対スコア}\\right)) \\) の相対評価スコアが得られ、その和が提出の得点となる。 最終順位はコンテスト終了後に実施されるより多くの入力に対するシステムテストにおける得点で決定される。 暫定テスト、システムテストともに、一部のテストケースで不正な出力や制限時間超過をした場合、そのテストケースの相対評価スコアは0点となり、そのテストケースにおいては「全参加者中の最小絶対スコア」の計算から除外される。 システムテストは CE 以外の結果を得た一番最後の提出に対してのみ行われるため、最終的に提出する解答を間違えないよう注意せよ。 #### テストケース数 - 暫定テスト: 50個 - システムテスト: 2000個 - コンテスト終了後に [seeds.txt](https://img.atcoder.jp/ahc036/seeds.txt) (sha256=`607aca150bd5f8f062937b02e6d14c15f7661aefbd279f150043e6d7e47f8d3c`) を公開します。 #### 相対評価システムについて 暫定テスト・システムテストともに、CE 以外の結果を得た一番最後の提出のみが順位表に反映されます。 相対評価スコアの計算に用いられる各テストケース毎の全参加者中の最小絶対スコアの算出についても、順位表に反映されている最終提出のみが用いられます。 順位表に表示されているスコアは相対評価スコアであり、新規提出があるたびに、相対評価スコアが再計算されます。 一方、提出一覧から確認出来る各提出のスコアは各テストケース毎の絶対スコアをそのまま足し合わせたものであり、相対評価スコアは表示されません。 最新以外の提出の、現在の順位表における相対評価スコアを知るためには、再提出が必要です。 不正な出力や制限時間超過をした場合、提出一覧から確認出来るスコアは0となりますが、順位表には正解したテストケースに対する相対評価スコアの和が表示されます。 #### 実行時間について 実行時間には多少のブレが生じます。 また、システムテストでは同時に大量の実行を行うため、暫定テストに比べて数%程度実行時間が伸びる現象が確認されています。 そのため、実行時間制限ギリギリの提出がシステムテストで TLE となる可能性があります。 プログラム内で時間を計測して処理を打ち切るか、実行時間に余裕を持たせるようお願いします。 ### 入力生成方法 入力生成方法の詳細$ L $ 以上 $ U $ 以下の整数を一様ランダムに生成する関数を $ \mathrm{rand}(L,\ U) $ とし、 $ L $ 以上 $ U $ 未満の実数を一様ランダムに生成する関数を $ \mathrm{rand\_double}(L,\ U) $ とする。 また、2つの頂点 $ u,\ v $ の距離を $ \sqrt{(x_u\ -\ x_v)^2\ +\ (y_u\ -\ y_v)^2} $ とする。 #### グラフの生成 グラフの生成に使用するパラメタ $ D_{vmin} $, $ D_{emax} $, $ P_{remove} $ を、それぞれ $ \mathrm{rand}(20,\ 30) $, $ \mathrm{rand}(80,\ 140) $, $ \mathrm{rand\_double}(0.0,\ 0.5) $ で生成する。 $ N\ =\ 600 $ として、$ i\ =\ 0,\ 1,\ \ldots\ N\ -\ 1 $ の順に以下の操作を行い頂点集合 $ V $ を生成する。 1\. $ x_i\ =\ \mathrm{rand}(0,1000),\ y_i\ =\ \mathrm{rand}(0,1000) $ として生成する。 2\. $ V $ に含まれる頂点に $ (x_i,\ y_i) $ との距離が $ D_{vmin} $ 未満のものが存在しなくなるまで、$ (x_i,\ y_i) $ を選び直す。 3\. $ V $ に $ (x_i,\ y_i) $ を加える。 辺集合 $ E $ を以下のようにして生成する。 1\. 距離が $ D_{emax}\ /\ 2 $ 以下の頂点ペアを全て列挙し、ランダムな順番に並び替える。各ペアについて順番に、すでに追加したどの辺とも交差しない場合 $ E $ に追加する。ここで、辺が交差するとは、頂点 $ i $ を座標 $ (x_i,\ y_i) $ に配置し、辺を両端点を結ぶ線分として描画した際に、2辺が共通の端点以外に共通点を持つことを表す。 2\. 距離が $ D_{emax}\ /\ 2 $ より大きく $ D_{emax} $ 以下であるような頂点ペアを全て列挙し、ランダムな順番に並び替える。各ペアについて順番に、すでに追加したどの辺とも交差しない場合に $ E $ に追加する。 この時点でグラフ $ (V,\ E) $ が連結でなければ $ V $ の生成からやり直す。 最後に、各辺 $ e\ \in\ E $ についてランダムな順に、$ e $ を取り除いてもグラフが連結であれば、確率 $ P_{remove} $ で $ E $ から $ e $ を取り除く。 #### $ t $ の生成 $ t_0 $ を $ \mathrm{rand}(1,\ N\ -\ 1) $ で生成する。 $ i\ =\ 1,\ 2,\ \ldots,\ T\ -\ 1 $ の順に、$ t_i $ を、$ 0 $ 以上 $ N\ -\ 1 $ 以下の整数のうち $ t_{i\ -1} $ 以外のものの中から一様ランダムに選ぶことで生成する。 #### $ L_A,\ L_B $ の生成 $ L_A $ を $ \mathrm{rand}(N,\ 2\ \times\ N) $ で生成する。 $ L_B $ を $ \mathrm{floor}{(\mathrm{rand\_double}(2.0,\ 5.0)^2)} $ で生成する。ここで、$ \mathrm{floor}{(x)} $ は $ x $ 以下の最大の整数を表す。 必ずしも理解する必要はありません。 厳密な実装は入力ジェネレータのソースコードをご覧ください。 ### ツール ### Sample Explanation 1 この入力は説明用のものなので、入力の制約を満たさないことに注意せよ。 出力 説明 ビジュアライズ ``` 0 1 3 4 5 6 2 ``` $ A $ の初期値を $ [0,\ 1,\ 3,\ 4,\ 5,\ 6,\ 2] $ とする。 初期状態では信号は全て赤である。 !\[\]() ``` s 4 0 0 ``` $ A $ の $ 0 $ 番目の要素から始まる長さ $ 4 $ の部分列を、 $ B $ の $ 0 $ 番目の要素を始点とする範囲に対して上書きする。 $ B $ の値は $ [0,\ 1,\ 3,\ 4] $ となる。 !\[\]() ``` m 3 m 4 ``` 頂点 $ 0\ →\ 3\ →\ 4 $ の順で最初の目的地の頂点へと移動する。 !\[\](