結果

問題 No.160 最短経路のうち辞書順最小
ユーザー knewknowlknewknowl
提出日時 2015-03-02 21:25:41
言語 C++11
(gcc 13.3.0)
結果
AC  
実行時間 23 ms / 5,000 ms
コード長 707 bytes
コンパイル時間 522 ms
コンパイル使用メモリ 64,728 KB
実行使用メモリ 6,944 KB
最終ジャッジ日時 2024-06-24 01:12:01
合計ジャッジ時間 1,727 ms
ジャッジサーバーID
(参考情報)
judge2 / judge4
このコードへのチャレンジ
(要ログイン)
ファイルパターン 結果
sample AC * 4
other AC * 26
権限があれば一括ダウンロードができます

ソースコード

diff #

#include <iostream>
#include <algorithm>
#include <vector>
using namespace std;
int G[200][200];
int D[200][200];
int main(){
  int n,m,s,g;cin>>n>>m>>s>>g;
  for(int i=0;i<n;++i) for(int j=0;j<n;++j) G[i][j] = (i==j)?0:1<<25;
  while(m--){
    int a,b,c;cin>>a>>b>>c;
    G[a][b]=G[b][a]=c;
    D[a][b]=D[b][a]=c;
  }
  for(int k=0;k<n;++k) for(int i=0;i<n;++i) for(int j=0;j<n;++j) G[i][j]=min(G[i][j],G[i][k]+G[k][j]);
  vector<int> root;root.push_back(s);
  while(true){
    for(int i=0;i<n;++i){
      if(D[s][i]&&D[s][i]+G[i][g]==G[s][g]){
	root.push_back(i);
	s=i;
	break;
      }
    }
    if(s==g) break;
  }
  for(int i=0,m=root.size();i<m;++i) cout << root[i]<<" ";
  cout << endl;
  return 0;
}
0