結果
| 問題 | No.3482 Quod Erat Demonstrandum |
| コンテスト | |
| ユーザー |
urectanc
|
| 提出日時 | 2026-03-27 22:08:03 |
| 言語 | Rust (1.93.0 + proconio + num + itertools) |
| 結果 |
AC
|
| 実行時間 | 105 ms / 2,000 ms |
| コード長 | 1,728 bytes |
| 記録 | |
| コンパイル時間 | 4,301 ms |
| コンパイル使用メモリ | 192,224 KB |
| 実行使用メモリ | 27,136 KB |
| 最終ジャッジ日時 | 2026-03-27 22:08:18 |
| 合計ジャッジ時間 | 12,818 ms |
|
ジャッジサーバーID (参考情報) |
judge1_1 / judge2_1 |
(要ログイン)
| ファイルパターン | 結果 |
|---|---|
| sample | AC * 1 |
| other | AC * 45 |
ソースコード
use std::collections::VecDeque;
use proconio::{fastout, input, marker::Usize1};
#[fastout]
fn main() {
input! { t: usize }
for _ in 0..t {
let ans = solve();
match ans {
Ans::Same(n) => {
println!("Same\n{n}");
}
Ans::Different(n) => {
println!("Different\n{n}");
}
Ans::Unknown => {
println!("Unknown");
}
}
}
}
enum Ans {
Same(usize),
Different(usize),
Unknown,
}
fn solve() -> Ans {
input! {
n: usize, m: usize,
rel: [(Usize1, Usize1, u8); m],
}
let mut graph = vec![vec![]; n];
for &(a, b, c) in &rel {
if c == 2 {
continue;
}
graph[a].push(b);
graph[b].push(a);
}
let bfs = |s: usize| {
let mut que = VecDeque::from([s]);
let mut dist = vec![!0usize; n];
dist[s] = 0;
while let Some(current) = que.pop_front() {
for &next in &graph[current] {
if dist[next] == !0 {
dist[next] = dist[current] + 1;
que.push_back(next);
}
}
}
dist
};
let d0 = bfs(0);
if d0[n - 1] != !0 {
return Ans::Same(d0[n - 1]);
}
let d1 = bfs(n - 1);
let mut min = !0usize;
for &(a, b, c) in &rel {
if c == 2 {
let cand1 = d0[a].saturating_add(d1[b]).saturating_add(1);
let cand2 = d1[a].saturating_add(d0[b]).saturating_add(1);
min = min.min(cand1).min(cand2);
}
}
if min < !0 {
Ans::Different(min)
} else {
Ans::Unknown
}
}
urectanc