結果
問題 | No.875 Range Mindex Query |
ユーザー | へのく |
提出日時 | 2019-09-06 21:39:21 |
言語 | Rust (1.77.0 + proconio) |
結果 |
CE
(最新)
AC
(最初)
|
実行時間 | - |
コード長 | 4,163 bytes |
コンパイル時間 | 12,860 ms |
コンパイル使用メモリ | 383,920 KB |
最終ジャッジ日時 | 2024-11-14 21:37:11 |
合計ジャッジ時間 | 13,981 ms |
ジャッジサーバーID (参考情報) |
judge1 / judge5 |
(要ログイン)
コンパイルエラー時のメッセージ・ソースコードは、提出者また管理者しか表示できないようにしております。(リジャッジ後のコンパイルエラーは公開されます)
ただし、clay言語の場合は開発者のデバッグのため、公開されます。
ただし、clay言語の場合は開発者のデバッグのため、公開されます。
コンパイルメッセージ
error[E0782]: trait objects must include the `dyn` keyword --> src/main.rs:49:13 | 49 | op: Box<Fn((i64, usize), (i64, usize)) -> (i64, usize) + 'a>, | ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ | help: add `dyn` keyword before this trait | 49 | op: Box<dyn Fn((i64, usize), (i64, usize)) -> (i64, usize) + 'a>, | +++ For more information about this error, try `rustc --explain E0782`. error: could not compile `main` (bin "main") due to 1 previous error
ソースコード
use std::io::{stdin, Read, StdinLock}; use std::str::FromStr; use std::iter::FromIterator; fn main() { let cin = stdin(); let mut scan = Scanner::new(cin.lock()); let n = scan.read::<usize>(); let q = scan.read::<usize>(); let a = scan.readn::<i64>(n); let mut segtree = SegTree::new(a, 1i64<<60, std::cmp::min); for _ in 0..q { let op = scan.read::<usize>(); let l = scan.read::<usize>()-1; let r = scan.read::<usize>()-1; if op == 1 { let ltmp = segtree.get_one(l).0; let rtmp = segtree.get_one(r).0; segtree.set(l, rtmp); segtree.set(r, ltmp); } else { let (_, i) = segtree.get(l..r+1); println!("{}", i+1); } } } use std::ops::Range; #[allow(dead_code)] fn contains(p: &Range<usize>, q: &Range<usize>) -> bool { p.start <= q.start && q.end <= p.end } #[allow(dead_code)] fn separates(p: &Range<usize>, q: &Range<usize>) -> bool { p.end <= q.start || q.end <= p.start } #[allow(dead_code)] fn size(p: &Range<usize>) -> usize { p.end - p.start } #[allow(dead_code)] struct SegTree<'a> { node: Vec<(i64, usize)>, zero: i64, op: Box<Fn((i64, usize), (i64, usize)) -> (i64, usize) + 'a>, n: usize, } #[allow(dead_code)] impl <'a> SegTree<'a> { fn new<B>(v: Vec<i64>, zero: i64, op: B) -> SegTree<'a> where B: Fn((i64, usize), (i64, usize)) -> (i64, usize) + 'a { let size = v.len(); let mut n = 1usize; while n < size {n *= 2} let mut node = vec![(zero, 0); 2*n-1]; for i in 0..size {node[i+n-1] = (v[i], i)} for i in (0..n - 1).rev() {node[i] = op(node[2*i+1], node[2*i+2])} SegTree {node: node, zero: zero, op: Box::new(op), n: n} } fn set(&mut self, mut x: usize, value: i64) { let y = x; x += self.n - 1; self.node[x] = (value, y); while x > 0 { x = (x - 1) / 2; self.node[x] = (self.op)(self.node[2*x+1], self.node[2*x+2]); } } fn get_one(&self, i: usize) -> (i64, usize) {self.getrec(i..i+1, 0, 0..self.n)} fn get(&self, query: Range<usize>) -> (i64, usize) {self.getrec(query, 0, 0..self.n)} fn getrec(&self, query: Range<usize>, k: usize, range: Range<usize>) -> (i64, usize) { if separates(&query, &range) {return (self.zero, 0)} if contains(&query, &range) {return self.node[k]} let vl = self.getrec(query.clone(), 2*k+1, range.start..(range.start + range.end)/2); let vr = self.getrec(query.clone(), 2*k+2, (range.start + range.end)/2..range.end); (self.op)(vl, vr) } } // region template #[allow(dead_code)] fn iu(i: isize) -> usize { i as usize } #[allow(dead_code)] fn ui(i: usize) -> isize { i as isize } #[allow(dead_code, deprecated)] fn join<T: std::fmt::Display>(slice: &[T], sep: &str) -> String { let strings = slice.iter().map(|t| format!("{}", t)).collect::<Vec<_>>(); strings.connect(sep) } #[allow(dead_code)] fn arr<'a, S, T>(n: usize, mut f: S) -> Vec<T> where S: FnMut(usize) -> T + 'a { (0..n).map(|i| f(i)).collect::<Vec<T>>() } #[allow(dead_code)] fn alt<S, T>(v: Vec<S>) -> T where T: FromIterator<S> { v.into_iter().collect::<T>() } #[allow(dead_code)] fn dup<S, T>(v: &[S]) -> T where T: FromIterator<S>, S: Clone { v.iter().cloned().collect::<T>() } struct Scanner<'a> { cin: StdinLock<'a>, } #[allow(dead_code)] impl<'a> Scanner<'a> { fn new(cin: StdinLock<'a>) -> Scanner<'a> { Scanner { cin: cin } } fn read1<T: FromStr>(&mut self) -> Option<T> { let token = self.cin.by_ref().bytes().map(|c| c.unwrap() as char) .skip_while(|c| c.is_whitespace()) .take_while(|c| !c.is_whitespace()) .collect::<String>(); token.parse::<T>().ok() } fn read<T: FromStr>(&mut self) -> T { self.read1().unwrap() } fn readn<T: FromStr>(&mut self, n: usize) -> Vec<T> { (0..n).map(|_| self.read::<T>()).collect() } fn chars(&mut self) -> Vec<char> { self.read::<String>().chars().collect() } } // endregion