結果
| 問題 |
No.1700 floor X
|
| コンテスト | |
| ユーザー |
|
| 提出日時 | 2021-10-28 20:33:00 |
| 言語 | Rust (1.83.0 + proconio) |
| 結果 |
AC
|
| 実行時間 | 16 ms / 2,000 ms |
| コード長 | 718 bytes |
| コンパイル時間 | 12,424 ms |
| コンパイル使用メモリ | 401,360 KB |
| 実行使用メモリ | 5,376 KB |
| 最終ジャッジ日時 | 2024-07-03 10:46:14 |
| 合計ジャッジ時間 | 14,202 ms |
|
ジャッジサーバーID (参考情報) |
judge1 / judge3 |
(要ログイン)
| ファイルパターン | 結果 |
|---|---|
| sample | AC * 1 |
| other | AC * 44 |
ソースコード
use std::io;
fn main() {
let n = read_input();
let mut v: Vec<u64> = Vec::new();
for _i in 0..n {
v.push(read_input());
}
for n in v {
println!("{}", sqrt_n(n));
}
}
fn read_input() -> u64 {
let mut s = String::new();
io::stdin().read_line(&mut s).unwrap();
s.trim().parse().unwrap()
}
fn sqrt_n(n: u64) -> u64 {
let mut l: u64 = 1;
let mut r: u64 = 1_000_000_001;
let mut m: u64 = (l + r) / 2;
let mut prev_m: u64 = m;
for _i in 0..100 {
if m * m > n {
r = m;
} else {
l = m;
}
m = (l + r) / 2;
if prev_m == m {
break;
}
prev_m = m;
}
m
}