結果
| 問題 |
No.875 Range Mindex Query
|
| コンテスト | |
| ユーザー |
へのく
|
| 提出日時 | 2019-09-06 21:39:21 |
| 言語 | Rust (1.83.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
へのく