結果
問題 |
No.1013 〇マス進む
|
ユーザー |
![]() |
提出日時 | 2020-03-22 20:54:12 |
言語 | Python3 (3.13.1 + numpy 2.2.1 + scipy 1.14.1) |
結果 |
WA
|
実行時間 | - |
コード長 | 645 bytes |
コンパイル時間 | 272 ms |
コンパイル使用メモリ | 12,800 KB |
実行使用メモリ | 153,300 KB |
最終ジャッジ日時 | 2024-12-26 00:17:37 |
合計ジャッジ時間 | 76,251 ms |
ジャッジサーバーID (参考情報) |
judge3 / judge4 |
(要ログイン)
ファイルパターン | 結果 |
---|---|
sample | AC * 2 WA * 1 |
other | AC * 2 WA * 45 TLE * 15 |
ソースコード
import sys input=lambda: sys.stdin.readline().rstrip() n,k=map(int,input().split()) P=[int(i) for i in input().split()] A=[[0]*n for i in range(31)] B=[[0]*n for i in range(31)] A[0]=P for i in range(n): A[1][i]=(A[0][i]+i+1)%n if A[0][i]+i+1>n: B[1][i]=1 if A[1][i]==0: A[1][i]=n for i in range(1,30): for j in range(n): A[i+1][j]=A[i][A[i][j]-1] B[i+1][j]=B[i][j]+B[i][A[i][j]-1] Ans1=[int(i)+1 for i in range(n)] Ans2=[0]*n for i in range(30): if k&(1<<i): for j in range(n): Ans1[j]=A[i+1][Ans1[j]-1] Ans2[j]+=B[i+1][j] Ans=[] for i in range(n): Ans.append(Ans1[i]+Ans2[i]*n) print(*Ans,sep="\n")