結果

問題 No.2569 はじめてのおつかいHard
ユーザー ragnaragna
提出日時 2023-11-14 14:39:39
言語 C++17
(gcc 12.3.0 + boost 1.83.0)
結果
AC  
実行時間 585 ms / 2,000 ms
コード長 1,497 bytes
コンパイル時間 2,269 ms
コンパイル使用メモリ 212,488 KB
実行使用メモリ 39,808 KB
最終ジャッジ日時 2024-09-26 03:36:55
合計ジャッジ時間 7,442 ms
ジャッジサーバーID
(参考情報)
judge4 / judge2
このコードへのチャレンジ
(要ログイン)

テストケース

テストケース表示
入力 結果 実行時間
実行使用メモリ
testcase_00 AC 264 ms
20,108 KB
testcase_01 AC 266 ms
20,236 KB
testcase_02 AC 264 ms
20,236 KB
testcase_03 AC 267 ms
20,236 KB
testcase_04 AC 265 ms
20,236 KB
testcase_05 AC 579 ms
38,656 KB
testcase_06 AC 448 ms
24,132 KB
testcase_07 AC 527 ms
39,296 KB
testcase_08 AC 585 ms
39,808 KB
testcase_09 AC 376 ms
24,632 KB
testcase_10 AC 2 ms
5,376 KB
testcase_11 AC 2 ms
5,376 KB
権限があれば一括ダウンロードができます

ソースコード

diff #

#include<bits/stdc++.h>
using namespace std;
using ll=long long;
using Pair=pair<ll,ll>;
const ll INF=1e18;

ll N,M;

//ダイクストラ法
//s:始点,G:参考にするグラフ,dist:距離を記録する配列
void dijkstra(ll s,vector<vector<Pair>> &G,vector<vector<ll>> &dist){
    priority_queue<Pair,vector<Pair>,greater<Pair>> que;
    que.push({0,s});
    while(!que.empty()){
        ll to=que.top().second,cost=que.top().first;
        if(cost<dist[to][s==N-1]){
            dist[to][s==N-1]=cost;
            for(auto&& [x,y]:G[to]){
                que.push({cost+y,x});
            }
        }
        que.pop();
    }
}

int main(){
    cin >> N >> M;
    vector<vector<Pair>> G1(N),G2(M);
    for(int k=0;k<M;k++){
        ll u,v,t; cin >> u >> v >> t;
        u--,v--;
        G1[u].push_back({v,t}); //そのまま
        G2[v].push_back({u,t}); //反転
    }
    vector<vector<ll>> dist1(N,vector<ll>(2,INF)),dist2(N,vector<ll>(2,INF));
    dijkstra(N-2,G1,dist1); //dist1[k][0]:N-2からk
    dijkstra(N-2,G2,dist2); //dist2[k][0]:kからN-2
    dijkstra(N-1,G1,dist1); //dist1[k][1]:N-1からk
    dijkstra(N-1,G2,dist2); //dist2[k][1]:kからN-1
    for(int k=0;k<N-2;k++){
        ll ans1=dist2[k][0]+dist1[N-1][0]+dist1[k][1]; //k→N-2→N-1→k
        ll ans2=dist2[k][1]+dist1[N-2][1]+dist1[k][0]; //k→N-1→N-2→k
        if(min(ans1,ans2)<INF){
            cout << min(ans1,ans2) << endl;
        }
        else{
            cout << -1 << endl;
        }
    }
}
0