結果

問題 No.91 赤、緑、青の石
コンテスト
ユーザー ducktail
提出日時 2018-05-11 16:05:52
言語 Haskell
(9.10.1)
結果
AC  
実行時間 3 ms / 5,000 ms
コード長 589 bytes
記録
記録タグの例:
初AC ショートコード 純ショートコード 純主流ショートコード 最速実行時間
コンパイル時間 1,073 ms
コンパイル使用メモリ 186,240 KB
実行使用メモリ 7,848 KB
最終ジャッジ日時 2025-12-07 12:31:45
合計ジャッジ時間 2,033 ms
ジャッジサーバーID
(参考情報)
judge4 / judge2
このコードへのチャレンジ
(要ログイン)
ファイルパターン 結果
sample AC * 4
other AC * 29
権限があれば一括ダウンロードができます
コンパイルメッセージ
Loaded package environment from /home/judge/.ghc/x86_64-linux-9.10.1/environments/default
[1 of 2] Compiling Main             ( Main.hs, Main.o )
[2 of 2] Linking a.out

ソースコード

diff #
raw source code

import Control.Applicative ((<$>))
import Data.List (sort)

main :: IO ()
main = solve <$> map read <$> words <$> getLine >>= print

solve :: [Int] -> Int
solve xs = bsearch (judge (a, b, c)) a c
  where [a, b, c] = sort xs

bsearch :: (Int -> Bool) -> Int -> Int -> Int
bsearch f o n | n - o <= 1 = o
              | f m = bsearch f m n
              | otherwise = bsearch f o m
  where m = (o + n) `div` 2

judge :: (Int, Int, Int) -> Int -> Bool
judge (a, b, c) m = (m > b && 2*m - a - b <= (c - m) `div` 2) ||
                    (m <= b && m - a <= (b - m) `div` 2 + (c - m) `div` 2)
0