結果
| 問題 | No.769 UNOシミュレータ | 
| コンテスト | |
| ユーザー |  ttr | 
| 提出日時 | 2020-05-27 22:30:38 | 
| 言語 | Python3 (3.13.1 + numpy 2.2.1 + scipy 1.14.1) | 
| 結果 | 
                                AC
                                 
                             | 
| 実行時間 | 881 ms / 2,000 ms | 
| コード長 | 673 bytes | 
| コンパイル時間 | 84 ms | 
| コンパイル使用メモリ | 12,544 KB | 
| 実行使用メモリ | 11,520 KB | 
| 最終ジャッジ日時 | 2024-10-13 03:52:45 | 
| 合計ジャッジ時間 | 7,620 ms | 
| ジャッジサーバーID (参考情報) | judge3 / judge5 | 
(要ログイン)
| ファイルパターン | 結果 | 
|---|---|
| other | AC * 23 | 
ソースコード
N,M = map(int, input().split())
ans = 0
prev = 0
next = 1
card = [0]*N
cnt = 0
for _ in range(M):
    l = input()
    card[ans] += 1
    if (prev == "drawtwo" or prev == "drawfour") and prev != l:
        card[ans] -= 1+cnt
        cnt = 0
        ans += next
        card[ans%N] += 1
    if l == "number" or l == "drawtwo" or l == "drawfour":
        ans += next
        if l == "drawtwo":
            cnt += 2
        elif l == "drawfour":
            cnt += 4
    elif l == "skip":
        ans += next*2
    elif l == "reverse":
        next *= -1
        ans += next
    prev = l
    ans %= N
if l == "skip":
    next *= 2
ans = (ans-next)%N+1
print(ans, card[ans-1])
            
            
            
        