結果
| 問題 |
No.1 道のショートカット
|
| コンテスト | |
| ユーザー |
vjudge1
|
| 提出日時 | 2025-09-04 11:34:21 |
| 言語 | Rust (1.83.0 + proconio) |
| 結果 |
AC
|
| 実行時間 | 2 ms / 5,000 ms |
| コード長 | 1,013 bytes |
| コンパイル時間 | 12,889 ms |
| コンパイル使用メモリ | 397,960 KB |
| 実行使用メモリ | 7,716 KB |
| 最終ジャッジ日時 | 2025-09-04 11:34:36 |
| 合計ジャッジ時間 | 14,680 ms |
|
ジャッジサーバーID (参考情報) |
judge4 / judge2 |
(要ログイン)
| ファイルパターン | 結果 |
|---|---|
| sample | AC * 4 |
| other | AC * 40 |
ソースコード
use proconio::input;
use std::cmp::min;
const INF: i32 = 1_000_000_000;
fn main() {
input! {
n: usize,
c: usize,
v: usize,
s: [usize; v],
t: [usize; v],
y: [usize; v],
m: [i32; v],
}
let mut graph = vec![vec![]; n];
for i in 0..v {
let from = s[i] - 1;
let to = t[i] - 1;
graph[from].push((to, y[i], m[i]));
}
let mut dp = vec![vec![INF; c + 1]; n];
dp[0][c] = 0;
for i in 0..n {
for k in (0..=c).rev() {
if dp[i][k] == INF {
continue;
}
for &(to, cost, time) in &graph[i] {
if k >= cost {
let new_k = k - cost;
dp[to][new_k] = min(dp[to][new_k], dp[i][k] + time);
}
}
}
}
let result = *dp[n - 1].iter().min().unwrap();
if result == INF {
println!("-1");
} else {
println!("{}", result);
}
}
vjudge1