結果

問題 No.1935 Water Simulation
ユーザー simansiman
提出日時 2022-05-14 05:04:53
言語 Ruby
(3.3.0)
結果
AC  
実行時間 79 ms / 2,000 ms
コード長 557 bytes
コンパイル時間 203 ms
コンパイル使用メモリ 11,304 KB
実行使用メモリ 15,324 KB
最終ジャッジ日時 2023-09-29 17:13:27
合計ジャッジ時間 4,123 ms
ジャッジサーバーID
(参考情報)
judge14 / judge12
このコードへのチャレンジ
(要ログイン)

テストケース

テストケース表示
入力 結果 実行時間
実行使用メモリ
testcase_00 AC 77 ms
15,020 KB
testcase_01 AC 79 ms
15,168 KB
testcase_02 AC 77 ms
15,188 KB
testcase_03 AC 77 ms
15,300 KB
testcase_04 AC 79 ms
15,032 KB
testcase_05 AC 77 ms
15,136 KB
testcase_06 AC 77 ms
15,224 KB
testcase_07 AC 76 ms
15,236 KB
testcase_08 AC 77 ms
15,020 KB
testcase_09 AC 77 ms
15,020 KB
testcase_10 AC 77 ms
15,160 KB
testcase_11 AC 77 ms
15,124 KB
testcase_12 AC 76 ms
15,128 KB
testcase_13 AC 76 ms
15,244 KB
testcase_14 AC 77 ms
15,024 KB
testcase_15 AC 76 ms
15,320 KB
testcase_16 AC 76 ms
15,032 KB
testcase_17 AC 77 ms
15,148 KB
testcase_18 AC 77 ms
15,296 KB
testcase_19 AC 76 ms
15,228 KB
testcase_20 AC 76 ms
15,164 KB
testcase_21 AC 77 ms
15,084 KB
testcase_22 AC 76 ms
15,196 KB
testcase_23 AC 76 ms
15,324 KB
testcase_24 AC 76 ms
15,312 KB
testcase_25 AC 77 ms
15,228 KB
testcase_26 AC 77 ms
15,116 KB
testcase_27 AC 77 ms
15,088 KB
testcase_28 AC 78 ms
15,192 KB
testcase_29 AC 78 ms
15,124 KB
testcase_30 AC 76 ms
15,192 KB
testcase_31 AC 76 ms
15,284 KB
権限があれば一括ダウンロードができます
コンパイルメッセージ
Syntax OK

ソースコード

diff #

V1, V2, V3, V4, N = gets.split.map(&:to_i)

cap = [V1, V2, V3, V4]
V = [V1, 0, 0, 0, 0]
E = Hash.new
head = []

(N + 1).times do |i|
  head << V.dup
  break if E[V]

  idx = i % 4
  n_idx = (idx + 1) % 4

  u = V.dup
  r = [V[idx], cap[n_idx] - V[n_idx]].min
  V[idx] -= r
  V[n_idx] += r
  V[-1] = (V[-1] + 1) % 4

  E[u] = V.dup
end

if N < head.size
  puts head[N][..-2].join(' ')
else
  n = N
  n -= (head.size - 1)

  last = head.pop
  r_idx = head.rindex(last)

  lp = head[r_idx..-1]
  ls = lp.size
  idx = n % ls

  puts lp[idx][..-2].join(' ')
end
0