結果
| 問題 | 
                            No.92 逃走経路
                             | 
                    
| コンテスト | |
| ユーザー | 
                             latte0119
                         | 
                    
| 提出日時 | 2016-01-13 18:53:01 | 
| 言語 | C++11(廃止可能性あり)  (gcc 13.3.0)  | 
                    
| 結果 | 
                             
                                AC
                                 
                             
                            
                         | 
                    
| 実行時間 | 6 ms / 5,000 ms | 
| コード長 | 873 bytes | 
| コンパイル時間 | 1,193 ms | 
| コンパイル使用メモリ | 162,644 KB | 
| 実行使用メモリ | 6,944 KB | 
| 最終ジャッジ日時 | 2024-09-19 18:56:50 | 
| 合計ジャッジ時間 | 1,938 ms | 
| 
                            ジャッジサーバーID (参考情報)  | 
                        judge3 / judge2 | 
(要ログイン)
| ファイルパターン | 結果 | 
|---|---|
| sample | AC * 2 | 
| other | AC * 18 | 
ソースコード
#include<bits/stdc++.h>
using namespace std;
#define int long long
#define rep(i,n) for(int i=0;i<(n);i++)
#define reps(i,f,n) for(int i=(f);i<(n);i++)
#define pb push_back
#define all(v) (v).begin(),(v).end()
typedef vector<int>vint;
typedef pair<int,int>pint;
typedef vector<pint>vpint;
int N,M,K;
int A[1000],B[1000],C[1000];
signed main(){
    cin>>N>>M>>K;
    rep(i,M)cin>>A[i]>>B[i]>>C[i],A[i]--,B[i]--;
    bool prev[100],next[100];
    fill_n(prev,N,true);
    while(K--){
        int d;cin>>d;
        rep(i,M)if(C[i]==d&&prev[A[i]])next[B[i]]=true;
        rep(i,M)if(C[i]==d&&prev[B[i]])next[A[i]]=true;
        rep(i,N)prev[i]=next[i];
        fill_n(next,N,false);
    }
    vint ans;
    rep(i,N)if(prev[i])ans.pb(i);
    cout<<ans.size()<<endl;
    rep(i,ans.size()){
        if(i)cout<<" ";
        cout<<ans[i]+1;
    }cout<<endl;
    return 0;
}
            
            
            
        
            
latte0119