結果
問題 | No.1332 Range Nearest Query |
ユーザー | くれちー |
提出日時 | 2021-01-08 22:26:22 |
言語 | Rust (1.77.0 + proconio) |
結果 |
AC
|
実行時間 | 1,808 ms / 2,500 ms |
コード長 | 17,790 bytes |
コンパイル時間 | 16,685 ms |
コンパイル使用メモリ | 378,764 KB |
実行使用メモリ | 13,896 KB |
最終ジャッジ日時 | 2024-11-16 13:15:11 |
合計ジャッジ時間 | 73,341 ms |
ジャッジサーバーID (参考情報) |
judge2 / judge1 |
(要ログイン)
テストケース
テストケース表示入力 | 結果 | 実行時間 実行使用メモリ |
---|---|---|
testcase_00 | AC | 1 ms
5,248 KB |
testcase_01 | AC | 2 ms
5,248 KB |
testcase_02 | AC | 2 ms
5,248 KB |
testcase_03 | AC | 1,808 ms
10,800 KB |
testcase_04 | AC | 1,695 ms
10,740 KB |
testcase_05 | AC | 1,736 ms
10,876 KB |
testcase_06 | AC | 1,548 ms
13,860 KB |
testcase_07 | AC | 1,436 ms
13,856 KB |
testcase_08 | AC | 1,476 ms
13,732 KB |
testcase_09 | AC | 1,471 ms
13,864 KB |
testcase_10 | AC | 1,447 ms
13,792 KB |
testcase_11 | AC | 1,420 ms
13,736 KB |
testcase_12 | AC | 1,427 ms
13,732 KB |
testcase_13 | AC | 1,429 ms
13,856 KB |
testcase_14 | AC | 1,446 ms
13,860 KB |
testcase_15 | AC | 1,445 ms
13,736 KB |
testcase_16 | AC | 1,701 ms
13,860 KB |
testcase_17 | AC | 1,711 ms
13,804 KB |
testcase_18 | AC | 1,742 ms
13,740 KB |
testcase_19 | AC | 1,726 ms
13,732 KB |
testcase_20 | AC | 1,734 ms
13,860 KB |
testcase_21 | AC | 1,733 ms
13,732 KB |
testcase_22 | AC | 1,714 ms
13,856 KB |
testcase_23 | AC | 1,721 ms
13,732 KB |
testcase_24 | AC | 1,722 ms
13,732 KB |
testcase_25 | AC | 1,712 ms
13,864 KB |
testcase_26 | AC | 778 ms
13,896 KB |
testcase_27 | AC | 797 ms
13,896 KB |
testcase_28 | AC | 97 ms
5,248 KB |
testcase_29 | AC | 128 ms
5,248 KB |
testcase_30 | AC | 159 ms
5,248 KB |
testcase_31 | AC | 45 ms
5,248 KB |
testcase_32 | AC | 167 ms
5,248 KB |
testcase_33 | AC | 167 ms
5,248 KB |
testcase_34 | AC | 88 ms
5,248 KB |
testcase_35 | AC | 99 ms
5,248 KB |
testcase_36 | AC | 98 ms
5,248 KB |
testcase_37 | AC | 127 ms
5,248 KB |
testcase_38 | AC | 1,322 ms
7,900 KB |
testcase_39 | AC | 790 ms
5,248 KB |
testcase_40 | AC | 1,711 ms
13,568 KB |
testcase_41 | AC | 1,028 ms
5,248 KB |
testcase_42 | AC | 1,287 ms
7,620 KB |
testcase_43 | AC | 1,133 ms
5,268 KB |
testcase_44 | AC | 1,536 ms
9,824 KB |
testcase_45 | AC | 1,481 ms
9,124 KB |
testcase_46 | AC | 1,240 ms
6,324 KB |
testcase_47 | AC | 1,406 ms
8,456 KB |
ソースコード
// The main code is at the very bottom. #[allow(unused_imports)] use { lib::byte::ByteChar, std::cell::{Cell, RefCell}, std::cmp::{ self, Ordering::{self, *}, Reverse, }, std::collections::*, std::convert::identity, std::fmt::{self, Debug, Display, Formatter}, std::io::prelude::*, std::iter::{self, FromIterator}, std::marker::PhantomData, std::mem, std::num::Wrapping, std::ops::{Range, RangeFrom, RangeInclusive, RangeTo, RangeToInclusive}, std::process, std::rc::Rc, std::thread, std::time::{Duration, Instant}, std::{char, f32, f64, i128, i16, i32, i64, i8, isize, str, u128, u16, u32, u64, u8, usize}, }; #[allow(unused_imports)] #[macro_use] pub mod lib { pub mod byte { pub use self::byte_char::*; mod byte_char { use std::error::Error; use std::fmt::{self, Debug, Display, Formatter}; use std::str::FromStr; #[derive(Clone, Copy, Default, PartialEq, Eq, PartialOrd, Ord, Hash)] #[repr(transparent)] pub struct ByteChar(pub u8); impl Debug for ByteChar { fn fmt(&self, f: &mut Formatter) -> fmt::Result { write!(f, "b'{}'", self.0 as char) } } impl Display for ByteChar { fn fmt(&self, f: &mut Formatter) -> fmt::Result { write!(f, "{}", self.0 as char) } } impl FromStr for ByteChar { type Err = ParseByteCharError; fn from_str(s: &str) -> Result<ByteChar, ParseByteCharError> { match s.as_bytes().len() { 1 => Ok(ByteChar(s.as_bytes()[0])), 0 => Err(ParseByteCharErrorKind::EmptyStr.into()), _ => Err(ParseByteCharErrorKind::TooManyBytes.into()), } } } #[derive(Clone, Copy, PartialEq, Eq, Hash, Debug)] pub struct ParseByteCharError { kind: ParseByteCharErrorKind, } impl Display for ParseByteCharError { fn fmt(&self, f: &mut Formatter) -> fmt::Result { f.write_str(match self.kind { ParseByteCharErrorKind::EmptyStr => "empty string", ParseByteCharErrorKind::TooManyBytes => "too many bytes", }) } } impl Error for ParseByteCharError {} #[derive(Clone, Copy, PartialEq, Eq, Hash, Debug)] enum ParseByteCharErrorKind { EmptyStr, TooManyBytes, } impl From<ParseByteCharErrorKind> for ParseByteCharError { fn from(kind: ParseByteCharErrorKind) -> ParseByteCharError { ParseByteCharError { kind } } } } } pub mod io { pub use self::scanner::*; mod scanner { use std::io::{self, BufRead}; use std::iter; use std::str::FromStr; #[derive(Debug)] pub struct Scanner<R> { reader: R, buf: String, pos: usize, } impl<R: BufRead> Scanner<R> { pub fn new(reader: R) -> Self { Scanner { reader, buf: String::new(), pos: 0, } } pub fn next(&mut self) -> io::Result<&str> { let start = loop { match self.rest().find(|c| c != ' ') { Some(i) => break i, None => self.fill_buf()?, } }; self.pos += start; let len = self.rest().find(' ').unwrap_or(self.rest().len()); let s = &self.buf[self.pos..][..len]; // self.rest()[..len] self.pos += len; Ok(s) } pub fn parse_next<T>(&mut self) -> io::Result<Result<T, T::Err>> where T: FromStr, { Ok(self.next()?.parse()) } pub fn parse_next_n<T>(&mut self, n: usize) -> io::Result<Result<Vec<T>, T::Err>> where T: FromStr, { iter::repeat_with(|| self.parse_next()).take(n).collect() } pub fn map_next_bytes<T, F>(&mut self, mut f: F) -> io::Result<Vec<T>> where F: FnMut(u8) -> T, { Ok(self.next()?.bytes().map(&mut f).collect()) } pub fn map_next_bytes_n<T, F>(&mut self, n: usize, mut f: F) -> io::Result<Vec<Vec<T>>> where F: FnMut(u8) -> T, { iter::repeat_with(|| self.map_next_bytes(&mut f)) .take(n) .collect() } fn rest(&self) -> &str { &self.buf[self.pos..] } fn fill_buf(&mut self) -> io::Result<()> { self.buf.clear(); self.pos = 0; let read = self.reader.read_line(&mut self.buf)?; if read == 0 { return Err(io::ErrorKind::UnexpectedEof.into()); } if *self.buf.as_bytes().last().unwrap() == b'\n' { self.buf.pop(); } Ok(()) } } } } } #[allow(dead_code)] mod n91lib_rs { pub mod data_structure { pub mod bit_vector { use crate::n91lib_rs::other::bit::access; use crate::n91lib_rs::other::bit::rank; use crate::n91lib_rs::other::bit::select; use crate::n91lib_rs::other::bit::WORD; use std::iter::FromIterator; use std::iter::IntoIterator; use std::iter::Iterator; pub struct BitVector { data: Box<[Node]>, } struct Node { bit: usize, sum: usize, } impl BitVector { pub fn access(&self, index: usize) -> bool { access(self.data[index / WORD].bit, index % WORD) } pub fn rank0(&self, end: usize) -> usize { end - self.rank1(end) } pub fn rank1(&self, end: usize) -> usize { let t = &self.data[end / WORD]; t.sum + rank(t.bit, end % WORD) } pub fn select0(&self, k: usize) -> usize { let (mut st, mut en) = (0, self.data.len()); while en - st != 1 { let mid = (st + en) / 2; if mid * WORD - self.data[mid].sum <= k { st = mid; } else { en = mid; } } let rem = k - (st * WORD - self.data[st].sum); st * WORD + select(!self.data[st].bit, rem) } pub fn select1(&self, k: usize) -> usize { let (mut st, mut en) = (0, self.data.len()); while en - st != 1 { let mid = (st + en) / 2; if self.data[mid].sum <= k { st = mid; } else { en = mid; } } let rem = k - self.data[st].sum; st * WORD + select(self.data[st].bit, rem) } } impl FromIterator<bool> for BitVector { fn from_iter<T: IntoIterator<Item = bool>>(iter: T) -> Self { let mut iter = iter.into_iter(); let mut v = Vec::new(); let mut sum = 0; 'base: loop { let mut bit = 0; for i in 0..WORD { match iter.next() { Some(v) => { if v { bit |= 1 << i; } } None => { v.push(Node { bit: bit, sum: sum }); break 'base; } } } v.push(Node { bit: bit, sum: sum }); sum += bit.count_ones() as usize; } Self { data: v.into_boxed_slice(), } } } } pub mod wavelet_matrix { use crate::n91lib_rs::data_structure::BitVector; use crate::n91lib_rs::other::bit::access; use std::ops::Range; pub struct WaveletMatrix { data: Box<[(usize, BitVector)]>, } impl WaveletMatrix { pub fn new(bitlen: usize, mut seq: Vec<usize>) -> Self { let len = seq.len(); let mut data = Vec::new(); for l in (0..bitlen).rev() { let v = seq.iter().map(|&x| access(x, l)).collect::<BitVector>(); data.push((v.rank0(len), v)); let zeros = seq.iter().filter(|&&x| !access(x, l)).cloned(); let ones = seq.iter().filter(|&&x| access(x, l)).cloned(); seq = zeros.chain(ones).collect(); } Self { data: data .into_iter() .rev() .collect::<Vec<_>>() .into_boxed_slice(), } } pub fn access(&self, mut index: usize) -> usize { let mut ret = 0; for (l, &(z, ref v)) in self.base_iter().rev() { if !v.access(index) { index = v.rank0(index); } else { ret |= 1 << l; index = z + v.rank1(index); } } ret } pub fn rank(&self, value: usize, mut range: Range<usize>) -> usize { for (l, &(z, ref v)) in self.base_iter().rev() { if !access(value, l) { range.start = v.rank0(range.start); range.end = v.rank0(range.end); } else { range.start = z + v.rank1(range.start); range.end = z + v.rank1(range.end); } } range.end - range.start } pub fn select(&self, value: usize, k: usize) -> usize { let mut index = 0; for (l, &(z, ref v)) in self.base_iter().rev() { if !access(value, l) { index = v.rank0(index); } else { index = z + v.rank1(index); } } index += k; for (_, &(z, ref v)) in self.base_iter() { if index < z { index = v.select0(index); } else { index = v.select1(index - z); } } index } pub fn count(&self, idxrng: Range<usize>, valrng: Range<usize>) -> usize { self.count_to(idxrng.clone(), valrng.end) - self.count_to(idxrng, valrng.start) } pub fn quantile(&self, mut range: Range<usize>, mut k: usize) -> usize { let mut ret = 0; for (l, &(z, ref v)) in self.base_iter().rev() { let zeros = v.rank0(range.end) - v.rank0(range.start); if zeros > k { range.start = v.rank0(range.start); range.end = v.rank0(range.end); } else { k -= zeros; ret |= 1 << l; range.start = z + v.rank1(range.start); range.end = z + v.rank1(range.end); } } ret } fn count_to(&self, mut range: Range<usize>, val: usize) -> usize { let mut ret = 0; for (l, &(z, ref v)) in self.base_iter().rev() { if !access(val, l) { range.start = v.rank0(range.start); range.end = v.rank0(range.end); } else { ret += v.rank0(range.end) - v.rank0(range.start); range.start = z + v.rank1(range.start); range.end = z + v.rank1(range.end); } } ret } fn base_iter(&self) -> impl DoubleEndedIterator<Item = (usize, &(usize, BitVector))> { self.data.iter().enumerate() } } } pub use bit_vector::BitVector; } pub mod other { pub mod bit { pub const WORD: usize = (0 as usize).count_zeros() as usize; pub fn access(bit: usize, index: usize) -> bool { bit & 1 << index != 0 } pub fn rank(bit: usize, end: usize) -> usize { (bit & !(!0 << end)).count_ones() as usize } #[cfg(any(target_arch = "x86", target_arch = "x86_64"))] pub fn select(bit: usize, k: usize) -> usize { macro_rules! select_impl { ($k: expr, $({$b: expr, $m: expr, $s: expr}),*) => { let mut k = $k; let mut r = 0; $( let b = ($b >> r & $m) as usize; if k >= b { k -= b; r += $s; } )* r } } #[cfg(target_arch = "x86")] { if is_x86_feature_detected!("bmi2") { use std::arch::x86::_pdep_u32; unsafe { _pdep_u32(1 << k, bit as u32).trailing_zeros() as usize } } else { let b0 = bit as u32; let b1 = (b0 & 0x55555555) + (b0 >> 1 & 0x55555555); let b2 = (b1 & 0x33333333) + (b1 >> 2 & 0x33333333); let b3 = b2 + (b2 >> 4) & 0x0F0F0F0F; let b4 = b3 + (b3 >> 8) & 0x00FF00FF; let b5 = b4 + (b4 >> 16) & 0x0000FFFF; if k >= b5 as usize { return 32; } #[allow(unused_assignments)] { select_impl! { k, {b4, 0xFFFF, 16}, {b3, 0xFF, 8}, {b2, 0xF, 4}, {b1, 0x3, 2}, {b0, 0x1, 1} } } } } #[cfg(target_arch = "x86_64")] { if is_x86_feature_detected!("bmi2") { use std::arch::x86_64::_pdep_u64; unsafe { _pdep_u64(1 << k, bit as u64).trailing_zeros() as usize } } else { let b0 = bit as u64; let b1 = (b0 & 0x5555555555555555) + (b0 >> 1 & 0x5555555555555555); let b2 = (b1 & 0x3333333333333333) + (b1 >> 2 & 0x3333333333333333); let b3 = b2 + (b2 >> 4) & 0x0F0F0F0F0F0F0F0F; let b4 = b3 + (b3 >> 8) & 0x00FF00FF00FF00FF; let b5 = b4 + (b4 >> 16) & 0x0000FFFF0000FFFF; let b6 = b5 + (b5 >> 32) & 0x00000000FFFFFFFF; if k >= b6 as usize { return 64; } #[allow(unused_assignments)] { select_impl! { k, {b5, 0xFFFFFFFF, 32}, {b4, 0xFFFF, 16}, {b3, 0xFF, 8}, {b2, 0xF, 4}, {b1, 0x3, 2}, {b0, 0x1, 1} } } } } } pub fn bsf(bit: usize) -> usize { assert_ne!(bit, 0); bit.trailing_zeros() as usize } pub fn bsr(bit: usize) -> usize { assert_ne!(bit, 0); WORD - 1 - bit.leading_zeros() as usize } pub fn ceil_log2(n: usize) -> usize { assert_ne!(n, 0); WORD - 1 - (2 * n - 1).leading_zeros() as usize } } } } #[allow(unused_macros)] macro_rules! eprint { ($($arg:tt)*) => { if cfg!(debug_assertions) { std::eprint!($($arg)*) } }; } #[allow(unused_macros)] macro_rules! eprintln { ($($arg:tt)*) => { if cfg!(debug_assertions) { std::eprintln!($($arg)*) } }; } #[allow(unused_macros)] macro_rules! dbg { ($($arg:tt)*) => { if cfg!(debug_assertions) { std::dbg!($($arg)*) } else { ($($arg)*) } }; } const CUSTOM_STACK_SIZE_MIB: Option<usize> = Some(1024); const INTERACTIVE: bool = false; fn main() -> std::io::Result<()> { match CUSTOM_STACK_SIZE_MIB { Some(stack_size_mib) => std::thread::Builder::new() .name("run_solver".to_owned()) .stack_size(stack_size_mib * 1024 * 1024) .spawn(run_solver)? .join() .unwrap(), None => run_solver(), } } fn run_solver() -> std::io::Result<()> { let stdin = std::io::stdin(); let reader = stdin.lock(); let stdout = std::io::stdout(); let writer = stdout.lock(); macro_rules! with_wrapper { ($($wrapper:expr)?) => {{ let mut writer = $($wrapper)?(writer); solve(reader, &mut writer)?; writer.flush() }}; } if cfg!(debug_assertions) || INTERACTIVE { with_wrapper!() } else { with_wrapper!(std::io::BufWriter::new) } } fn solve<R, W>(reader: R, mut writer: W) -> std::io::Result<()> where R: BufRead, W: Write, { let mut _scanner = lib::io::Scanner::new(reader); #[allow(unused_macros)] macro_rules! scan { ($T:ty) => { _scanner.parse_next::<$T>()?.unwrap() }; ($($T:ty),+) => { ($(scan!($T)),+) }; ($T:ty; $n:expr) => { _scanner.parse_next_n::<$T>($n)?.unwrap() }; ($($T:ty),+; $n:expr) => { iter::repeat_with(|| -> std::io::Result<_> { Ok(($(scan!($T)),+)) }) .take($n) .collect::<std::io::Result<Vec<_>>>()? }; } #[allow(unused_macros)] macro_rules! scan_bytes_map { ($f:expr) => { _scanner.map_next_bytes($f)? }; ($f:expr; $n:expr) => { _scanner.map_next_bytes_n($n, $f)? }; } #[allow(unused_macros)] macro_rules! print { ($($arg:tt)*) => { write!(writer, $($arg)*)? }; } #[allow(unused_macros)] macro_rules! println { ($($arg:tt)*) => { writeln!(writer, $($arg)*)? }; } #[allow(unused_macros)] macro_rules! answer { ($($arg:tt)*) => {{ println!($($arg)*); return Ok(()); }}; } { use n91lib_rs::data_structure::wavelet_matrix::WaveletMatrix; fn dist(x: usize, y: usize) -> usize { if x > y { x - y } else { y - x } } let n = scan!(usize); let x = scan!(usize; n); let wm = WaveletMatrix::new(30, x); let q = scan!(usize); for _ in 0..q { let (l, r, x) = scan!(usize, usize, usize); let (l, r) = (l - 1, r - 1); let nth = |i| wm.quantile(l..r + 1, i); let mut ok = 0; let mut ng = n; while ng - ok > 1 { let mid = (ok + ng) / 2; if nth(mid) <= x { ok = mid; } else { ng = mid; } } let mut ans = dist(x, nth(ok)); if ok + 1 < r - l + 1 { ans = ans.min(dist(x, nth(ok + 1))); } println!("{}", ans); } } #[allow(unreachable_code)] Ok(()) }