結果
| 問題 | No.101 ぐるぐる!あみだくじ! |
| コンテスト | |
| ユーザー |
HIROPON87069639
|
| 提出日時 | 2016-02-16 21:28:12 |
| 言語 | Python2 (2.7.18) |
| 結果 |
AC
|
| 実行時間 | 16 ms / 5,000 ms |
| コード長 | 687 bytes |
| コンパイル時間 | 51 ms |
| コンパイル使用メモリ | 7,040 KB |
| 実行使用メモリ | 6,944 KB |
| 最終ジャッジ日時 | 2024-09-22 07:18:49 |
| 合計ジャッジ時間 | 1,673 ms |
|
ジャッジサーバーID (参考情報) |
judge3 / judge4 |
(要ログイン)
| ファイルパターン | 結果 |
|---|---|
| sample | AC * 3 |
| other | AC * 37 |
ソースコード
# -*- coding: utf-8 -*-
def gcd(a, b):
while b:
a, b = b, a % b
return a
def lcm(a, b):
return a * b / gcd(a, b)
N = input()
K = input()
Alist = [i+1 for i in range(0, N)]
Blist = [i+1 for i in range(0, N)]
Clist = [0 for i in range(0, N)]
Klist = [0 for i in range(0, K)]
for i in range(0, K):
Klist[i] = map(int, raw_input().split())[0] - 1
for i in Klist:
Blist[i], Blist[i+1] = Blist[i+1], Blist[i]
cnt = 0
for i in range(0, N):
cnt += 1
for j in range(0, N):
Alist[j] = Blist[Alist[j]-1]
if Clist[j] == 0 and Alist[j] == j+1:
Clist[j] = cnt
cnt = 1
for i in range(0, N):
cnt = lcm(cnt, Clist[i])
print cnt
HIROPON87069639