結果

問題 No.967 引き算をして門松列(その2)
ユーザー simansiman
提出日時 2022-11-15 12:37:56
言語 Ruby
(3.3.0)
結果
AC  
実行時間 112 ms / 2,000 ms
コード長 1,623 bytes
コンパイル時間 790 ms
コンパイル使用メモリ 11,480 KB
実行使用メモリ 15,492 KB
最終ジャッジ日時 2023-10-14 18:21:40
合計ジャッジ時間 4,428 ms
ジャッジサーバーID
(参考情報)
judge12 / judge13
このコードへのチャレンジ
(要ログイン)

テストケース

テストケース表示
入力 結果 実行時間
実行使用メモリ
testcase_00 AC 71 ms
15,292 KB
testcase_01 AC 71 ms
15,140 KB
testcase_02 AC 74 ms
15,044 KB
testcase_03 AC 87 ms
15,220 KB
testcase_04 AC 86 ms
15,492 KB
testcase_05 AC 87 ms
15,300 KB
testcase_06 AC 87 ms
15,492 KB
testcase_07 AC 89 ms
15,340 KB
testcase_08 AC 99 ms
15,288 KB
testcase_09 AC 111 ms
15,472 KB
testcase_10 AC 111 ms
15,460 KB
testcase_11 AC 112 ms
15,492 KB
権限があれば一括ダウンロードができます
コンパイルメッセージ
Main.rb:117: warning: ambiguous first argument; put parentheses or a space even after `-' operator
Syntax OK

ソースコード

diff #

T = gets.to_i

def f1(a, b, c, x, y, z)
  cost = 0

  if a >= b
    diff = a - b + 1
    cost += x * diff
    a -= diff
  end

  if b <= c
    diff = c - b + 1
    cost += z * diff
    c -= diff
  end

  if a <= c
    diff = c - a + 1
    cost += z * diff
    c -= diff
  end

  return Float::INFINITY if a <= 0
  return Float::INFINITY if c <= 0

  cost
end

def f2(a, b, c, x, y, z)
  cost = 0

  if a >= b
    diff = a - b + 1
    cost += x * diff
    a -= diff
  end

  if b <= c
    diff = c - b + 1
    cost += z * diff
    c -= diff
  end

  if a >= c
    diff = a - c + 1
    cost += x * diff
    a -= diff
  end

  return Float::INFINITY if a <= 0
  return Float::INFINITY if c <= 0

  cost
end

def f3(a, b, c, x, y, z)
  cost = 0

  if a <= c
    diff = c - a + 1
    cost += z * diff
    c -= diff
  end

  if a <= b
    diff = b - a + 1
    cost += y * diff
    b -= diff
  end

  if b >= c
    diff = b - c + 1
    cost += y * diff
    b -= diff
  end

  return Float::INFINITY if b <= 0
  return Float::INFINITY if c <= 0

  cost
end

def f4(a, b, c, x, y, z)
  cost = 0

  if a >= c
    diff = a - c + 1
    cost += x * diff
    a -= diff
  end

  if a <= b
    diff = b - a + 1
    cost += y * diff
    b -= diff
  end

  if b >= c
    diff = b - c + 1
    cost += y * diff
    b -= diff
  end

  return Float::INFINITY if b <= 0
  return Float::INFINITY if a <= 0

  cost
end

T.times do
  a, b, c, x, y, z = gets.split.map(&:to_i)

  res = [f1(a, b, c, x, y, z), f2(a, b, c, x, y, z), f3(a, b, c, x, y, z), f4(a, b, c, x, y, z)].min

  if res == Float::INFINITY
    puts -1
  else
    puts res
  end
end
0