結果
問題 | No.2916 累進コスト最小化 |
ユーザー |
|
提出日時 | 2024-10-04 22:14:05 |
言語 | Rust (1.83.0 + proconio) |
結果 |
AC
|
実行時間 | 419 ms / 3,500 ms |
コード長 | 1,850 bytes |
コンパイル時間 | 12,600 ms |
コンパイル使用メモリ | 378,148 KB |
実行使用メモリ | 5,248 KB |
最終ジャッジ日時 | 2024-10-05 01:06:49 |
合計ジャッジ時間 | 17,966 ms |
ジャッジサーバーID (参考情報) |
judge3 / judge1 |
(要ログイン)
ファイルパターン | 結果 |
---|---|
other | AC * 34 |
ソースコード
use std::{borrow::Cow, cmp::Reverse, collections::BinaryHeap};use proconio::{input, marker::Usize1};fn main() {input! {(num_islands, num_edges, max_c): (usize, usize, usize),ijrm: [(Usize1, Usize1, usize, usize); num_edges],}let mut graph = vec![vec![]; num_islands];for &(i, j, r, m) in &ijrm {graph[i].push(Edge {from: i,to: j,denom: r,base_cost: m,});graph[j].push(Edge {from: j,to: i,denom: r,base_cost: m,});}let solve = |init_money: usize| {let mut sum_costs: Vec<Option<usize>> = vec![None; num_islands];let mut heap = BinaryHeap::from([(Reverse(0_usize), 0_usize)]);while let Some((Reverse(sum_cost), cur)) = heap.pop() {if sum_costs[cur].is_some() {continue;}sum_costs[cur] = Some(sum_cost);let next_node_iter = graph[cur].iter().filter_map(|edge| {let next_cost = sum_cost + (init_money - sum_cost) / edge.denom + edge.base_cost;if next_cost <= init_money {Some((Reverse(next_cost), edge.to))} else {None}});heap.extend(next_node_iter);}sum_costs[num_islands - 1].map(|sum_cost| init_money - sum_cost)};for c in 1..=max_c {let ans = solve(c);println!("{}",match ans {Some(rem) => rem.to_string().into(),None => Cow::Borrowed("-1"),});}}#[allow(dead_code)]#[derive(Debug, Clone, Copy)]struct Edge {from: usize,to: usize,denom: usize,base_cost: usize,}