Submission #6471773
Source Code Expand
Copy
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
הההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההה
XXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXX
//! ----------------------------------------------
//! Framework <https://github.com/vain0x/procon>
//!
//! See the bottom of file for solution.
//! ----------------------------------------------
#![allow(unused_imports)]
#![allow(non_snake_case)]
use std::cell::RefCell;
use std::cmp::{max, min, Ordering};
use std::collections::*;
use std::fmt::{Debug, Display, Formatter, Write as FmtWrite};
use std::io::{stderr, stdin, BufRead, Write};
use std::mem::{replace, swap};
use std::ops::*;
use std::rc::Rc;
/// Print values to standard error if debug mode.
#[allow(unused_macros)]
macro_rules! debug {
($($e:expr),*) => {
#[cfg(debug_assertions)]
$({
let (e, mut err) = (stringify!($e), stderr());
writeln!(err, "\x1B[33m{}\x1B[0m = {:?}", e, $e).unwrap()
})*
};
}
/// Read from standard input and parse each word.
/// - `read!(T, U, ..)` parses a line as a tuple of words.
/// - `read![[T]]` parses a line as an array of words.
/// - `read![..; N]` parses `N` lines, using `read!(..)` repeatedly.
#[allow(unused_macros)]
macro_rules! read {
([$t:ty] ; $n:expr) =>
((0..$n).map(|_| read!([$t])).collect::<Vec<_>>());
($($t:ty),+ ; $n:expr) =>
((0..$n).map(|_| read!($($t),+)).collect::<Vec<_>>());
([$t:ty]) =>
(rl().split_whitespace().map(|w| w.parse().unwrap()).collect::<Vec<$t>>());
($($t:ty),*) => {{
let buf = rl();
let mut w = buf.split_whitespace();
($(w.next().unwrap().parse::<$t>().unwrap()),*)
}};
}
/// Read a line from standard input.
#[allow(dead_code)]
fn rl() -> String {
let mut buf = String::new();
stdin().read_line(&mut buf).unwrap();
#[allow(deprecated)]
buf.trim_right().to_owned()
}
// -----------------------------------------------
// Solution
// -----------------------------------------------
// 最小値のうち右端を探す
// それより右側にある中で、最小値のうち右端を探す
// これを繰り返して見つかった点に同じ色を塗る
// ここで色を塗った要素を削除して、繰り返す
/*
8
1
4
7
2
8
5
3
6
=> 3
*/
#[derive(PartialEq, Clone, Debug)]
struct Interval<T> {
l: T,
r: T,
}
impl<T: Ord> Interval<T> {
fn new(l: T, r: T) -> Interval<T> {
Interval { l: l, r: r }
}
fn disjoint(&self, other: &Self) -> bool {
self.r <= other.l || other.r <= self.l
}
fn covers(&self, other: &Self) -> bool {
self.l <= other.l && other.r <= self.r
}
}
#[derive(Debug)]
pub struct SegTree<T, F> {
len: usize,
/// Number of leaf nodes.
width: usize,
/// len = `2w-1` for `w-1` inners and `w` leaves,
/// where `w` is the smallest `2^p` (`>= len`).
node: Vec<T>,
mempty: T,
mappend: F,
}
impl<T, F> SegTree<T, F>
where
T: Clone,
F: Fn(T, T) -> T,
{
pub fn new(items: Vec<T>, mempty: T, mappend: F) -> SegTree<T, F> {
let len = items.len();
let mut w = 1;
while w < len {
w *= 2;
}
debug_assert!(w >= len);
let mut node = vec![mempty.clone(); 2 * w - 1];
for (ei, item) in items.into_iter().enumerate() {
node[w - 1 + ei] = item;
}
for ni in (0..w - 1).rev() {
node[ni] = mappend(node[2 * ni + 1].clone(), node[2 * ni + 2].clone());
}
SegTree {
len: len,
width: w,
node: node,
mempty: mempty,
mappend: mappend,
}
}
pub fn len(&self) -> usize {
self.len
}
pub fn set(&mut self, ei: usize, value: T) {
let mut ni = self.width - 1 + ei;
self.node[ni] = value;
while ni > 0 {
ni = (ni - 1) / 2;
self.node[ni] =
(self.mappend)(self.node[2 * ni + 1].clone(), self.node[2 * ni + 2].clone());
}
}
pub fn sum(&self, ql: usize, qr: usize) -> T {
let q = Interval::new(ql, qr);
if q.disjoint(&Interval::new(0, self.len())) {
self.mempty.clone()
} else {
self.sum_core(0, Interval::new(0, self.width), &q)
}
}
fn sum_core(&self, ni: usize, e: Interval<usize>, q: &Interval<usize>) -> T {
if e.disjoint(&q) {
self.mempty.clone()
} else if q.covers(&e) {
self.node[ni].clone()
} else {
let m = (e.l + e.r) / 2;
let vl = self.sum_core(2 * ni + 1, Interval::new(e.l, m), q);
let vr = self.sum_core(2 * ni + 2, Interval::new(m, e.r), q);
(self.mappend)(vl.clone(), vr.clone())
}
}
}
#[derive(PartialEq, Eq, Clone, Debug)]
pub struct Rev<T>(pub T);
impl<T: PartialOrd> PartialOrd for Rev<T> {
fn partial_cmp(&self, other: &Rev<T>) -> Option<Ordering> {
other.0.partial_cmp(&self.0)
}
}
impl<T: Ord> Ord for Rev<T> {
fn cmp(&self, other: &Rev<T>) -> Ordering {
other.0.cmp(&self.0)
}
}
fn main() {
let N = read!(usize);
let A = read![i64; N];
let mut count = 0;
let empty = (std::i64::MAX, Rev(N));
let mut t = SegTree::new(
A.into_iter()
.enumerate()
.map(|(i, a)| (a, Rev(i)))
.collect(),
empty.clone(),
min,
);
loop {
let (_, Rev(j)) = t.sum(0, N);
if j >= N {
break;
}
t.set(j, empty.clone());
let mut i = j + 1;
while i < N {
let (_, Rev(j)) = t.sum(i, N);
if j >= N {
break;
}
t.set(j, empty.clone());
i = j + 1;
}
count += 1;
}
println!("{}", count)
}
Submission Info
Submission Time |
|
Task |
E - Sequence Decomposing |
User |
vain0 |
Language |
Rust (1.15.1) |
Score |
500 |
Code Size |
5975 Byte |
Status |
AC |
Exec Time |
89 ms |
Memory |
10492 KB |
Judge Result
Set Name |
All |
Sample |
Score / Max Score |
500 / 500 |
0 / 0 |
Status |
|
|
Set Name |
Test Cases |
All |
all_same, killer_01, killer_02, killer_03, killer_04, killer_05, many_dup_01, many_dup_02, many_dup_03, many_dup_04, many_dup_05, many_dup_06, many_dup_07, many_dup_08, many_dup_09, many_dup_10, many_dup_11, many_dup_12, rand_max_01, rand_max_02, rand_max_03, rand_max_04, rand_max_05, rand_max_06, rand_max_07, rand_max_08, rand_max_09, rand_max_10, rand_max_11, sample_01, sample_02, sorted_ascending, sorted_descending, unique_perm_01, unique_perm_02 |
Sample |
sample_01, sample_02 |
Case Name |
Status |
Exec Time |
Memory |
all_same |
AC |
80 ms |
10492 KB |
killer_01 |
AC |
88 ms |
10492 KB |
killer_02 |
AC |
84 ms |
10492 KB |
killer_03 |
AC |
89 ms |
10492 KB |
killer_04 |
AC |
80 ms |
10492 KB |
killer_05 |
AC |
84 ms |
10492 KB |
many_dup_01 |
AC |
75 ms |
10492 KB |
many_dup_02 |
AC |
76 ms |
10492 KB |
many_dup_03 |
AC |
74 ms |
10492 KB |
many_dup_04 |
AC |
76 ms |
10492 KB |
many_dup_05 |
AC |
78 ms |
10492 KB |
many_dup_06 |
AC |
69 ms |
10492 KB |
many_dup_07 |
AC |
74 ms |
10492 KB |
many_dup_08 |
AC |
77 ms |
10492 KB |
many_dup_09 |
AC |
66 ms |
10492 KB |
many_dup_10 |
AC |
79 ms |
10492 KB |
many_dup_11 |
AC |
79 ms |
10492 KB |
many_dup_12 |
AC |
68 ms |
10492 KB |
rand_max_01 |
AC |
74 ms |
10492 KB |
rand_max_02 |
AC |
73 ms |
10492 KB |
rand_max_03 |
AC |
72 ms |
10492 KB |
rand_max_04 |
AC |
72 ms |
10492 KB |
rand_max_05 |
AC |
71 ms |
10492 KB |
rand_max_06 |
AC |
72 ms |
10492 KB |
rand_max_07 |
AC |
74 ms |
10492 KB |
rand_max_08 |
AC |
77 ms |
10492 KB |
rand_max_09 |
AC |
71 ms |
10492 KB |
rand_max_10 |
AC |
74 ms |
10492 KB |
rand_max_11 |
AC |
74 ms |
10492 KB |
sample_01 |
AC |
2 ms |
4352 KB |
sample_02 |
AC |
2 ms |
4352 KB |
sorted_ascending |
AC |
65 ms |
10492 KB |
sorted_descending |
AC |
82 ms |
10492 KB |
unique_perm_01 |
AC |
71 ms |
10492 KB |
unique_perm_02 |
AC |
70 ms |
10492 KB |