結果
| 問題 | No.1097 Remainder Operation |
| コンテスト | |
| ユーザー |
|
| 提出日時 | 2021-05-24 09:33:21 |
| 言語 | Lua (LuaJit 2.1.1734355927) |
| 結果 |
AC
|
| 実行時間 | 1,233 ms / 2,000 ms |
| コード長 | 831 bytes |
| 記録 | |
| コンパイル時間 | 324 ms |
| コンパイル使用メモリ | 5,248 KB |
| 実行使用メモリ | 314,824 KB |
| 最終ジャッジ日時 | 2024-10-12 17:10:59 |
| 合計ジャッジ時間 | 15,604 ms |
|
ジャッジサーバーID (参考情報) |
judge3 / judge1 |
(要ログイン)
| ファイルパターン | 結果 |
|---|---|
| sample | AC * 2 |
| other | AC * 21 |
ソースコード
local mfl, mce = math.floor, math.ceil
local n = io.read("*n")
local a = {}
for i = 0, n - 1 do
a[i] = io.read("*n")
end
local up = {{}}
local t = {{}}
for i = 0, n - 1 do
local dst = (i + a[i]) % n
t[1][i] = dst
up[1][i] = 1LL * mfl((i + a[i]) / n)
end
-- print(table.concat(t[1], " "))
for i = 2, 45 do
t[i] = {}
up[i] = {}
for j = 0, n - 1 do
local z = t[i - 1][j]
t[i][j] = t[i - 1][z]
up[i][j] = up[i - 1][j] + up[i - 1][z]
end
-- print(table.concat(t[i], " "))
end
local q = io.read("*n")
for iq = 1, q do
local k = io.read("*n")
local cur = 0
local u = 0LL
for i = 1, 45 do
if k == 0 then break end
if k % 2 == 1 then
u = u + up[i][cur]
cur = t[i][cur]
end
k = mfl(k / 2)
end
local z = u * n + cur
local zs = tostring(z):gsub("LL", "")
print(zs)
end