Submission #16245387
Source Code Expand
use std::io::*;
fn read<T: std::str::FromStr>(
stdin_lock: &mut std::io::StdinLock,
buf: &mut Vec<u8>,
delimiter: u8,
) -> T {
buf.clear();
let l = std::io::BufRead::read_until(stdin_lock, delimiter, buf).unwrap();
buf.truncate(l - 1); // remove delimiter
let s = unsafe { std::str::from_utf8_unchecked(&buf) };
s.parse().unwrap_or_else(|_| panic!("read"))
}
fn is_male(s: &str) -> Option<bool> {
match s {
"Vacant" => None,
"Male" => Some(true),
"Female" => Some(false),
_ => unreachable!(),
}
}
fn main() {
let stdin = std::io::stdin();
let mut stdin_lock = stdin.lock();
let mut buf: Vec<u8> = Vec::new();
let n: usize = read(&mut stdin_lock, &mut buf, b'\n');
println!("{}", 0);
std::io::stdout().flush().ok();
let s: String = read(&mut stdin_lock, &mut buf, b'\n');
let s_0 = is_male(s.as_str());
if s_0.is_none() {
return;
}
println!("{}", n - 1);
std::io::stdout().flush().ok();
let s: String = read(&mut stdin_lock, &mut buf, b'\n');
let s_n1 = is_male(s.as_str());
if s_n1.is_none() {
return;
}
let mut l = 0;
let mut r = n - 1;
for _ in 0..20 {
let m = l + (r - l) / 2;
println!("{}", m);
std::io::stdout().flush().ok();
let s: String = read(&mut stdin_lock, &mut buf, b'\n');
let s_m = is_male(s.as_str());
if s_m.is_none() {
return;
}
if (m % 2 == 0 && s_m == s_0) || (m % 2 != 0 && s_m == s_n1) {
l = m;
} else {
r = m;
}
}
}
Submission Info
| Submission Time | |
|---|---|
| Task | C - Vacant Seat |
| User | bouzuya |
| Language | Rust (1.42.0) |
| Score | 500 |
| Code Size | 1694 Byte |
| Status | AC |
| Exec Time | 18 ms |
| Memory | 3832 KiB |
Judge Result
| Set Name | Sample | All | ||||
|---|---|---|---|---|---|---|
| Score / Max Score | 0 / 0 | 500 / 500 | ||||
| Status |
|
|
| Set Name | Test Cases |
|---|---|
| Sample | 0_00.txt |
| All | 0_00.txt, 1_00.txt, 1_01.txt, 1_02.txt, 1_03.txt, 1_04.txt, 1_05.txt, 1_06.txt, 1_07.txt, 1_08.txt, 1_09.txt, 1_10.txt, 1_11.txt, 1_12.txt, 1_13.txt, 1_14.txt, 1_15.txt, 1_16.txt, 1_17.txt, 1_18.txt, 1_19.txt, 1_20.txt, 1_21.txt, 1_22.txt, 1_23.txt, 1_24.txt, 1_25.txt, 1_26.txt, 1_27.txt, 1_28.txt, 1_29.txt, 1_30.txt, 1_31.txt, 1_32.txt, 1_33.txt, 1_34.txt, 1_35.txt, 1_36.txt, 1_37.txt, 1_38.txt, 1_39.txt, 1_40.txt, 1_41.txt, 1_42.txt, 1_43.txt, 1_44.txt, 1_45.txt, 1_46.txt, 1_47.txt, 1_48.txt |
| Case Name | Status | Exec Time | Memory |
|---|---|---|---|
| 0_00.txt | AC | 15 ms | 3632 KiB |
| 1_00.txt | AC | 7 ms | 3608 KiB |
| 1_01.txt | AC | 8 ms | 3696 KiB |
| 1_02.txt | AC | 6 ms | 3676 KiB |
| 1_03.txt | AC | 6 ms | 3540 KiB |
| 1_04.txt | AC | 3 ms | 3596 KiB |
| 1_05.txt | AC | 7 ms | 3632 KiB |
| 1_06.txt | AC | 5 ms | 3608 KiB |
| 1_07.txt | AC | 7 ms | 3632 KiB |
| 1_08.txt | AC | 7 ms | 3636 KiB |
| 1_09.txt | AC | 4 ms | 3608 KiB |
| 1_10.txt | AC | 10 ms | 3608 KiB |
| 1_11.txt | AC | 5 ms | 3536 KiB |
| 1_12.txt | AC | 4 ms | 3608 KiB |
| 1_13.txt | AC | 9 ms | 3752 KiB |
| 1_14.txt | AC | 10 ms | 3732 KiB |
| 1_15.txt | AC | 6 ms | 3740 KiB |
| 1_16.txt | AC | 10 ms | 3804 KiB |
| 1_17.txt | AC | 11 ms | 3756 KiB |
| 1_18.txt | AC | 9 ms | 3772 KiB |
| 1_19.txt | AC | 9 ms | 3772 KiB |
| 1_20.txt | AC | 10 ms | 3788 KiB |
| 1_21.txt | AC | 9 ms | 3772 KiB |
| 1_22.txt | AC | 17 ms | 3752 KiB |
| 1_23.txt | AC | 9 ms | 3764 KiB |
| 1_24.txt | AC | 15 ms | 3736 KiB |
| 1_25.txt | AC | 8 ms | 3736 KiB |
| 1_26.txt | AC | 11 ms | 3736 KiB |
| 1_27.txt | AC | 8 ms | 3776 KiB |
| 1_28.txt | AC | 11 ms | 3780 KiB |
| 1_29.txt | AC | 9 ms | 3768 KiB |
| 1_30.txt | AC | 17 ms | 3732 KiB |
| 1_31.txt | AC | 11 ms | 3780 KiB |
| 1_32.txt | AC | 8 ms | 3800 KiB |
| 1_33.txt | AC | 10 ms | 3736 KiB |
| 1_34.txt | AC | 13 ms | 3720 KiB |
| 1_35.txt | AC | 11 ms | 3796 KiB |
| 1_36.txt | AC | 10 ms | 3732 KiB |
| 1_37.txt | AC | 9 ms | 3832 KiB |
| 1_38.txt | AC | 10 ms | 3800 KiB |
| 1_39.txt | AC | 18 ms | 3672 KiB |
| 1_40.txt | AC | 12 ms | 3804 KiB |
| 1_41.txt | AC | 18 ms | 3764 KiB |
| 1_42.txt | AC | 9 ms | 3668 KiB |
| 1_43.txt | AC | 16 ms | 3764 KiB |
| 1_44.txt | AC | 10 ms | 3740 KiB |
| 1_45.txt | AC | 13 ms | 3724 KiB |
| 1_46.txt | AC | 11 ms | 3804 KiB |
| 1_47.txt | AC | 13 ms | 3780 KiB |
| 1_48.txt | AC | 10 ms | 3776 KiB |