結果

問題 No.149 碁石の移動
ユーザー taktak
提出日時 2019-02-14 14:35:46
言語 F#
(F# 4.0)
結果
AC  
実行時間 61 ms / 2,000 ms
コード長 730 bytes
コンパイル時間 5,075 ms
コンパイル使用メモリ 162,196 KB
実行使用メモリ 24,344 KB
最終ジャッジ日時 2023-10-11 12:37:49
合計ジャッジ時間 7,231 ms
ジャッジサーバーID
(参考情報)
judge15 / judge14
このコードへのチャレンジ
(要ログイン)

テストケース

テストケース表示
入力 結果 実行時間
実行使用メモリ
testcase_00 AC 58 ms
22,132 KB
testcase_01 AC 57 ms
22,188 KB
testcase_02 AC 58 ms
22,260 KB
testcase_03 AC 59 ms
22,304 KB
testcase_04 AC 61 ms
24,304 KB
testcase_05 AC 59 ms
22,356 KB
testcase_06 AC 59 ms
24,344 KB
testcase_07 AC 57 ms
20,256 KB
testcase_08 AC 59 ms
24,324 KB
testcase_09 AC 58 ms
22,176 KB
testcase_10 AC 58 ms
22,172 KB
testcase_11 AC 58 ms
22,268 KB
testcase_12 AC 58 ms
22,372 KB
testcase_13 AC 59 ms
24,272 KB
testcase_14 AC 58 ms
22,184 KB
testcase_15 AC 58 ms
22,336 KB
testcase_16 AC 58 ms
22,236 KB
権限があれば一括ダウンロードができます
コンパイルメッセージ
Microsoft (R) F# Compiler version 11.0.0.0 for F# 5.0
Copyright (c) Microsoft Corporation. All Rights Reserved.

ソースコード

diff #

type Bag = { 
  WhiteStone: int 
  BlackStone: int }

let solve a b c d =
  let c_b = min a.BlackStone c
  let c_w = c - c_b
  let a' = { WhiteStone = a.WhiteStone - c_w; BlackStone = a.BlackStone - c_b }
  let b' = { WhiteStone = b.WhiteStone + c_w; BlackStone = b.BlackStone + c_b }
 
  let d_w = min b'.WhiteStone d 
  let d_b = d - d_w
  // let a'' = { WhiteStone = a'.WhiteStone + d_w; BlackStone = a'.BlackStone + d_b }
  // let b'' ...

  a'.WhiteStone + d_w

let R() = stdin.ReadLine().Split() |> Array.map int

let A = 
  let t = R()
  { WhiteStone = t.[0]; BlackStone = t.[1] }
let B = 
  let t = R()
  { WhiteStone = t.[0]; BlackStone = t.[1] }
let C, D =
  let t = R()
  t.[0], t.[1]

solve A B C D
|> stdout.WriteLine
0