結果
| 問題 | No.1004 サイコロの実装 (2) | 
| コンテスト | |
| ユーザー |  lam6er | 
| 提出日時 | 2025-04-16 15:51:30 | 
| 言語 | PyPy3 (7.3.15) | 
| 結果 | 
                                TLE
                                 
                             | 
| 実行時間 | - | 
| コード長 | 1,260 bytes | 
| コンパイル時間 | 293 ms | 
| コンパイル使用メモリ | 81,848 KB | 
| 実行使用メモリ | 69,916 KB | 
| 最終ジャッジ日時 | 2025-04-16 15:52:31 | 
| 合計ジャッジ時間 | 5,386 ms | 
| ジャッジサーバーID (参考情報) | judge5 / judge1 | 
(要ログイン)
| ファイルパターン | 結果 | 
|---|---|
| sample | AC * 2 | 
| other | AC * 24 TLE * 1 -- * 13 | 
ソースコード
a, b, x0, N = map(int, input().split())
a_mod6 = a % 6
b_mod6 = b % 6
s0 = x0 % 6
# Find the cycle of x_i mod6
visited = {}
history = [s0]  # history[0] = x0 mod6
current = s0
step = 0
while True:
    next_s = (a_mod6 * current + b_mod6) % 6
    if next_s in visited:
        break
    visited[next_s] = step + 1  # step+1 is the index in history where next_s is stored
    history.append(next_s)
    current = next_s
    step += 1
cycle_start = visited[next_s]
cycle = history[cycle_start:]
cycle_len = len(cycle)
M = 2 * N
t_black = 0
t_white = 0
a_black = 0
a_white = 0
t_parity = 0
a_parity = 0
for i in range(M):
    # Calculate x_{i+1} mod6
    if i + 1 < len(history):
        s_i_plus_1 = history[i + 1]
    else:
        pos_in_cycle = (i + 1 - cycle_start) % cycle_len
        s_i_plus_1 = cycle[pos_in_cycle]
    
    parity = 1 - (s_i_plus_1 % 2)
    
    if (i + 1) % 2 == 1:  # Takahashi's turn (1st, 3rd, 5th steps)
        t_parity ^= parity
        if t_parity:
            t_black += 1
        else:
            t_white += 1
    else:  # Aoki's turn (2nd, 4th, 6th steps)
        a_parity ^= parity
        if a_parity:
            a_black += 1
        else:
            a_white += 1
print(min(t_black, t_white), min(a_black, a_white))
            
            
            
        