グラフの転置を求める
頂点数 v と辺数 e を持つ有向グラフが与えられたとき、その転置を求めなさい。
有向グラフの転置とは、すべての辺の向きを逆にすることで得られるグラフを指します。つまり、元のグラフにあるすべての有向辺を反転させたものです。

グラフの転置は、逆方向の経路や逆関係を調べる際に役立ちます。本コースの後半では、その具体的な応用についても取り上げる予定です。
入力
入力の最初の行には、整数 v (1 ≤ v ≤ 100 000) と e (1 ≤ e ≤ 100 000) が与えられます。
続く e 行には、v1 と v2 (1 ≤ v1, v2 ≤ v) が与えられ、これは頂点 v1 と頂点 v2 が辺で結ばれていることを意味します。
出力
プログラムは、補グラフ (complement graph) の隣接リストを出力してください。各行は、頂点のIDを書いた後にセミコロン (:) を置き、続けてその頂点に隣接する頂点を空白区切りで並べます。頂点および接続先の順番は任意です。
例
入力 | 出力 |
|---|---|
4 4 | 1: |
Constraints
Time limit: 3.5 seconds
Memory limit: 512 MB
Output limit: 1 MB