結果

問題 No.1595 The Final Digit
ユーザー NS
提出日時 2021-07-10 12:27:21
言語 PyPy3
(7.3.15)
結果
AC  
実行時間 48 ms / 2,000 ms
コード長 645 bytes
コンパイル時間 184 ms
コンパイル使用メモリ 82,176 KB
実行使用メモリ 59,648 KB
最終ジャッジ日時 2024-07-02 01:53:07
合計ジャッジ時間 1,802 ms
ジャッジサーバーID
(参考情報)
judge2 / judge1
このコードへのチャレンジ
(要ログイン)
ファイルパターン 結果
sample AC * 3
other AC * 17
権限があれば一括ダウンロードができます

ソースコード

diff #

p,q,r,k=map(int, input().split())
p%=10
q%=10
r%=10

MAX=10**3
gl=[-1]*MAX
for a1 in range(10):
    for a2 in range(10):
        for a3 in range(10):
            a0=(a1+a2+a3)%10
            val_f=a1*100+a2*10+a3
            val_t=a2*100+a3*10+a0
            gl[val_f]=val_t

from math import log2
logk = int(log2(k))+1
db = [ [0]*MAX for _ in range(logk) ]
for ni in range(MAX): 
    db[0][ni] = gl[ni]
for ki in range(logk-1):
    for ni in range(MAX):
        db[ki+1][ni] = db[ki][db[ki][ni]]

# k=3
# k-=1
# k+=2
# k-=3
k-=1
now = p*100+q*10+r
for i in range(logk):
    if k&(1<<i) > 0:
        now = db[i][now]
print(now//100)
# print(now)
0