結果
問題 | No.326 あみだますたー |
ユーザー |
|
提出日時 | 2016-01-11 12:06:52 |
言語 | Python3 (3.13.1 + numpy 2.2.1 + scipy 1.14.1) |
結果 |
AC
|
実行時間 | 74 ms / 2,000 ms |
コード長 | 1,179 bytes |
コンパイル時間 | 311 ms |
コンパイル使用メモリ | 12,672 KB |
実行使用メモリ | 11,776 KB |
最終ジャッジ日時 | 2024-11-07 23:24:50 |
合計ジャッジ時間 | 2,629 ms |
ジャッジサーバーID (参考情報) |
judge5 / judge1 |
(要ログイン)
ファイルパターン | 結果 |
---|---|
sample | AC * 2 |
other | AC * 26 |
ソースコード
def bubble_sort(target): ans = [] for n in range(len(target) - 1, 0, -1): for i in range(n): if target[i] > target[i + 1]: ans.append((i + 1, i + 2)) target[i], target[i + 1] = target[i + 1], target[i] return ans[::-1] def sim(now, line): m = dict() for i in range(1, len(now) + 1): no = i for x, y in line: if no == x: no = y elif no == y: no = x # now[i - 1]番は棒noに m[no] = now[i - 1] to = [] for k, v in sorted(m.items()): to.append(v) return to def main(): n = int(input()) k = int(input()) l = [] for _ in range(k): x, y = map(int, input().split()) l.append((x, y)) target = list(map(int, input().split())) to = sim(list(range(1, n + 1)), l) m = dict() for i in range(1, len(to) + 1): m[to[i - 1]] = i t = sorted([(x, i) for i, x in enumerate(target, start=1)]) t = [m[x] for i, x in t] ans = bubble_sort(t) print(len(ans)) for x in ans: print(x[0], x[1]) if __name__ == '__main__': main()