結果
| 問題 |
No.1013 〇マス進む
|
| コンテスト | |
| ユーザー |
takakin
|
| 提出日時 | 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")
takakin