結果
問題 |
No.2428 Returning Shuffle
|
ユーザー |
|
提出日時 | 2023-08-18 22:27:07 |
言語 | PyPy3 (7.3.15) |
結果 |
WA
|
実行時間 | - |
コード長 | 908 bytes |
コンパイル時間 | 720 ms |
コンパイル使用メモリ | 82,176 KB |
実行使用メモリ | 271,144 KB |
最終ジャッジ日時 | 2024-11-28 08:14:46 |
合計ジャッジ時間 | 5,431 ms |
ジャッジサーバーID (参考情報) |
judge5 / judge4 |
(要ログイン)
ファイルパターン | 結果 |
---|---|
sample | AC * 3 |
other | AC * 15 WA * 8 |
ソースコード
import math def lcm(a, b): return a * b // math.gcd(a, b) def main(): n, m = map(int, input().split()) vec = list(range(n)) for _ in range(m): input_data = list(map(int, input().split())) t = input_data[0] rol = list(map(lambda x: int(x) - 1, input_data[1:])) rol.reverse() x = vec[rol[0]] for j in range(t - 1): vec[rol[j]] = vec[rol[j + 1]] vec[rol[t - 1]] = x ans = 1 che = [0] * n for i in range(n): if che[i] == 1: continue x = vec[i] sum_val = 0 while True: sum_val += 1 che[x] = 1 if vec[x] == i: break x = vec[x] if sum_val == 1: continue ans = lcm(ans, sum_val + 1) mod = 998244353 print(ans % mod) if __name__ == "__main__": main()