結果

問題 No.2916 累進コスト最小化
ユーザー atcoder8
提出日時 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
権限があれば一括ダウンロードができます

ソースコード

diff #

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,
}
0