結果

問題 No.1042 愚直大学
ユーザー yosaka
提出日時 2020-05-18 09:42:06
言語 Nim
(2.2.0)
結果
AC  
実行時間 2 ms / 2,000 ms
コード長 636 bytes
コンパイル時間 3,686 ms
コンパイル使用メモリ 73,344 KB
実行使用メモリ 5,248 KB
最終ジャッジ日時 2024-10-01 21:54:17
合計ジャッジ時間 4,450 ms
ジャッジサーバーID
(参考情報)
judge1 / judge5
このコードへのチャレンジ
(要ログイン)
ファイルパターン 結果
sample AC * 2
other AC * 23
権限があれば一括ダウンロードができます
コンパイルメッセージ
/home/judge/data/code/Main.nim(1, 62) Warning: Use the new 'sugar' module instead; future is deprecated [Deprecated]
/home/judge/data/code/Main.nim(1, 8) Warning: imported and not used: 'streams' [UnusedImport]
/home/judge/data/code/Main.nim(1, 17) Warning: imported and not used: 'deques' [UnusedImport]
/home/judge/data/code/Main.nim(1, 62) Warning: imported and not used: 'future' [UnusedImport]
/home/judge/data/code/Main.nim(1, 84) Warning: imported and not used: 'hashes' [UnusedImport]
/home/judge/data/code/Main.nim(1, 45) Warning: imported and not used: 'algorithm' [UnusedImport]
/home/judge/data/code/Main.nim(1, 76) Warning: imported and not used: 'tables' [UnusedImport]

ソースコード

diff #

import streams, deques, sequtils, strutils, algorithm, math, future, sets, tables, hashes
proc `ceilDiv`*[T](x, y: T): T = x div y + ord(x mod y != 0)
proc `//=`*(x: var SomeInteger; y: SomeInteger) = x = x div y
proc `%=`*(x: var SomeInteger; y: SomeInteger) = x = x mod y


var
    L = stdin.readLine.split.map(parseFloat)
    P = L[0]
    Q = L[1]
    ldx = 0.0.float64
    rdx = float(10^12).float64
    mid = ((rdx + ldx) / 2).float64
while rdx - ldx > 0.00001:
    mid = (rdx + ldx) / 2
    if mid^2 <= Q * mid * log2(mid) + P:
        ldx = mid
    elif mid^2 > Q * mid * log2(mid) + P:
        rdx = mid
    # echo mid
echo mid
0