結果
問題 | No.1162 Many Quotients hard |
ユーザー |
|
提出日時 | 2022-12-02 16:24:39 |
言語 | Python3 (3.13.1 + numpy 2.2.1 + scipy 1.14.1) |
結果 |
AC
|
実行時間 | 34 ms / 2,000 ms |
コード長 | 587 bytes |
コンパイル時間 | 99 ms |
コンパイル使用メモリ | 12,416 KB |
実行使用メモリ | 10,880 KB |
最終ジャッジ日時 | 2024-10-09 18:07:57 |
合計ジャッジ時間 | 2,742 ms |
ジャッジサーバーID (参考情報) |
judge3 / judge4 |
(要ログイン)
ファイルパターン | 結果 |
---|---|
sample | AC * 2 |
other | AC * 42 |
ソースコード
from math import sqrt, floor def floor_sqrt(num: int) -> int: tmp = floor(sqrt(num)) while tmp ** 2 > num: tmp -= 1 while (tmp+1) ** 2 <= num: tmp += 1 return tmp def main(): N = int(input()) n = floor_sqrt(N+1) - 1 if n * (n + 2) == N: print(n * 2) return if n*(n+2) + (n + 1) >= N: print(n*2 + 1) return if n*(n+2) + (n + 1) + (n+2) >= N: print(n*2+2) return if n*(n+2) + (n + 1) + 2*(n+2) >= N: print(n*2+3) return if __name__ == "__main__": main()