| Task: | Company Queries II |
| Sender: | Giaco |
| Submission time: | 2025-10-23 19:49:52 +0300 |
| Language: | Rust (2021) |
| Status: | READY |
| Result: | ACCEPTED |
| test | verdict | time | |
|---|---|---|---|
| #1 | ACCEPTED | 0.00 s | details |
| #2 | ACCEPTED | 0.00 s | details |
| #3 | ACCEPTED | 0.00 s | details |
| #4 | ACCEPTED | 0.00 s | details |
| #5 | ACCEPTED | 0.00 s | details |
| #6 | ACCEPTED | 0.72 s | details |
| #7 | ACCEPTED | 0.50 s | details |
| #8 | ACCEPTED | 0.62 s | details |
| #9 | ACCEPTED | 0.78 s | details |
| #10 | ACCEPTED | 0.71 s | details |
| #11 | ACCEPTED | 0.00 s | details |
| #12 | ACCEPTED | 0.84 s | details |
Compiler report
warning: unused imports: `Reverse`, `max`, `min`
--> input/code.rs:1:16
|
1 | use std::cmp::{max, min, Reverse};
| ^^^ ^^^ ^^^^^^^
|
= note: `#[warn(unused_imports)]` on by default
warning: unused imports: `BTreeMap`, `BinaryHeap`, `HashMap`, `HashSet`
--> input/code.rs:2:24
|
2 | use std::collections::{BTreeMap, BinaryHeap, HashMap, HashSet};
| ^^^^^^^^ ^^^^^^^^^^ ^^^^^^^ ^^^^^^^
warning: unused import: `std::process::exit`
--> input/code.rs:4:5
|
4 | use std::process::exit;
| ^^^^^^^^^^^^^^^^^^
warning: 3 warnings emittedCode
use std::cmp::{max, min, Reverse};
use std::collections::{BTreeMap, BinaryHeap, HashMap, HashSet};
use std::io::{self, Read};
use std::process::exit;
macro_rules! input {
($it: expr) => {
$it.next().unwrap().parse().unwrap()
};
($it: expr, $T: ty) => {
$it.next().unwrap().parse::<$T>().unwrap()
};
}
/*
mod classes;
mod homework;
fn main() {
// println!("{}", "-".repeat(20));
// classes::c15::task2();
homework::hw6::task1();
// println!("{}", "-".repeat(20));
}
// */
fn dfs(v: usize, p: usize, d: usize, c: &Vec<Vec<usize>>,
depth: &mut Vec<usize>, up: &mut Vec<Vec<usize>>) {
depth[v] = d;
up[v][0] = p;
for &child in &c[v] {
dfs(child, v, d + 1, c, depth, up);
}
}
fn main() {
let mut buf = String::new();
io::stdin().read_to_string(&mut buf).unwrap();
let mut it = buf.split_whitespace();
let (n, q): (usize, usize) = (input!(it), input!(it));
if n == 1 {
for _ in 0..q {
let (_a, _b): (usize, usize) = (input!(it), input!(it));
println!("1");
}
return;
}
let v: Vec<usize> = (0..n-1).map(|_| input!(it)).collect();
let mut p = vec![0; n + 1];
p[1] = 0;
for i in 0..n - 1 {
p[i + 2] = v[i];
}
let log = 20;
let mut up = vec![vec![0; log]; n + 1];
let mut depth = vec![0; n + 1];
let mut c = vec![Vec::new(); n + 1];
for i in 2..=n {
c[p[i]].push(i);
}
dfs(1, 0, 0, &c, &mut depth, &mut up);
for j in 1..log {
for i in 1..=n {
up[i][j] = up[up[i][j - 1]][j - 1];
}
}
let lca = |mut a: usize, mut b: usize| -> usize {
if depth[a] < depth[b] {
std::mem::swap(&mut a, &mut b);
}
let mut remaining = depth[a] - depth[b];
for j in 0..log {
if remaining % 2 == 1 {
a = up[a][j];
}
remaining /= 2;
}
if a == b {
return a;
}
for j in (0..log).rev() {
if up[a][j] != up[b][j] {
a = up[a][j];
b = up[b][j];
}
}
up[a][0]
};
for _ in 0..q {
let (a, b): (usize, usize) = (input!(it), input!(it));
println!("{}", lca(a, b));
}
}Test details
Test 1
Verdict: ACCEPTED
| input |
|---|
| 10 10 1 2 3 4 5 6 7 8 9 6 9 8 10 10 3 ... |
| correct output |
|---|
| 6 8 3 1 8 ... |
| user output |
|---|
| 6 8 3 1 8 ... |
Test 2
Verdict: ACCEPTED
| input |
|---|
| 10 10 1 1 1 1 1 1 1 1 1 1 7 3 4 4 1 ... |
| correct output |
|---|
| 1 1 1 1 1 ... |
| user output |
|---|
| 1 1 1 1 1 ... |
Test 3
Verdict: ACCEPTED
| input |
|---|
| 10 10 1 1 1 1 2 3 4 4 1 1 8 2 7 8 3 ... |
| correct output |
|---|
| 1 1 1 1 1 ... |
| user output |
|---|
| 1 1 1 1 1 ... |
Test 4
Verdict: ACCEPTED
| input |
|---|
| 10 10 1 1 3 1 2 2 5 3 9 7 2 7 6 3 9 ... |
| correct output |
|---|
| 2 2 3 1 1 ... |
| user output |
|---|
| 2 2 3 1 1 ... |
Test 5
Verdict: ACCEPTED
| input |
|---|
| 10 10 1 2 3 2 5 3 2 2 4 6 1 1 3 1 9 ... |
| correct output |
|---|
| 1 1 1 2 2 ... |
| user output |
|---|
| 1 1 1 2 2 ... |
Test 6
Verdict: ACCEPTED
| input |
|---|
| 200000 200000 1 2 3 4 5 6 7 8 9 10 11 12 13 ... |
| correct output |
|---|
| 74862 8750 16237 72298 58111 ... |
| user output |
|---|
| 74862 8750 16237 72298 58111 ... |
Test 7
Verdict: ACCEPTED
| input |
|---|
| 200000 200000 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 ... |
| correct output |
|---|
| 1 1 1 1 1 ... |
| user output |
|---|
| 1 1 1 1 1 ... |
Test 8
Verdict: ACCEPTED
| input |
|---|
| 200000 200000 1 2 1 2 3 2 1 6 3 1 10 12 13 4... |
| correct output |
|---|
| 1 2 2 2 1 ... |
| user output |
|---|
| 1 2 2 2 1 ... |
Test 9
Verdict: ACCEPTED
| input |
|---|
| 200000 200000 1 2 3 4 5 6 7 8 9 10 11 12 13 ... |
| correct output |
|---|
| 2796 633 633 151 2690 ... |
| user output |
|---|
| 2796 633 633 151 2690 ... |
Test 10
Verdict: ACCEPTED
| input |
|---|
| 200000 200000 1 2 3 4 5 6 7 8 9 10 11 12 13 ... |
| correct output |
|---|
| 365 73 103 365 216 ... |
| user output |
|---|
| 365 73 103 365 216 ... |
Test 11
Verdict: ACCEPTED
| input |
|---|
| 2 4 1 1 1 1 2 2 1 ... |
| correct output |
|---|
| 1 1 1 2 |
| user output |
|---|
| 1 1 1 2 |
Test 12
Verdict: ACCEPTED
| input |
|---|
| 200000 200000 1 1 2 3 4 5 6 7 8 9 10 11 12 1... |
| correct output |
|---|
| 27468 6353 27468 6353 6353 ... |
| user output |
|---|
| 27468 6353 27468 6353 6353 ... |
