結果
| 問題 |
No.92 逃走経路
|
| コンテスト | |
| ユーザー |
motxx
|
| 提出日時 | 2014-12-07 21:58:57 |
| 言語 | C++11(廃止可能性あり) (gcc 13.3.0) |
| 結果 |
WA
|
| 実行時間 | - |
| コード長 | 2,110 bytes |
| コンパイル時間 | 1,727 ms |
| コンパイル使用メモリ | 176,916 KB |
| 実行使用メモリ | 34,176 KB |
| 最終ジャッジ日時 | 2024-06-11 17:39:50 |
| 合計ジャッジ時間 | 23,709 ms |
|
ジャッジサーバーID (参考情報) |
judge4 / judge3 |
(要ログイン)
| ファイルパターン | 結果 |
|---|---|
| sample | AC * 2 |
| other | AC * 17 WA * 1 |
ソースコード
#include <bits/stdc++.h>
using namespace std;
#define REP(i,a,b) for(int i=a;i<(int)b;i++)
#define rep(i,n) REP(i,0,n)
//typedef long long ll;
typedef int ll;
ll const INF = 1<<29;
struct EDGE {
ll u, v, c;
EDGE(ll u=0, ll v=0, ll c=INF) : u(u), v(v), c(c)
{}
bool operator < (EDGE const& e) const {
return c < e.c;
}
};
struct Edge {
ll to, cost;
};
typedef vector<Edge> Edges;
typedef vector<Edges> Graph;
Graph g;
vector<ll> d;
bool vlistb[1100][110];
ll N, M, K;
vector<vector<EDGE> > v;
//set<ll> ans;
bool ansb[110]; int ansc;
bool memo[110][1100]; //[idx][depth]
vector<EDGE> es;
void dfs(int idx, ll depth) {
if(memo[idx][depth]) return;
if(depth == K) {
if(!ansb[idx]) ansc++, ansb[idx] = 1;
// ans.insert(idx);
return ;
}
memo[idx][depth] = 1;
rep(i, g[idx].size()) {
Edge& e = g[idx][i];
if(!vlistb[depth][e.to]) continue;
if(d[depth] != e.cost) continue;
dfs(e.to, depth+1);
}
}
int main() {
cin >> N >> M >> K;
es.resize(M);
g.resize(N+1);
rep(i, M) {
ll a, b, c; cin >> a >> b >> c; a--, b--;
es[i].u = a, es[i].v = b, es[i].c = c;
}
d.resize(K);
rep(i, K) cin >> d[i];
sort(es.begin(), es.end());
es.push_back(EDGE(0,0,INF));
v.resize(K);
rep(i, K) {
auto uiter = upper_bound(es.begin(), es.end(), EDGE(0,0,d[i]));
auto liter = lower_bound(es.begin(), es.end(), EDGE(0,0,d[i]));
for(auto iter=liter; iter!=uiter; iter++) {
v[i].push_back(*iter);
}
}
rep(i, K) {
rep(j, v[i].size()) {
vlistb[i][v[i][j].u] = 1;
vlistb[i][v[i][j].v] = 1;
g[v[i][j].u].push_back((Edge){v[i][j].v, v[i][j].c});
g[v[i][j].v].push_back((Edge){v[i][j].u, v[i][j].c});
}
}
rep(i, N) {
if(vlistb[0][i]) { dfs(i, 0); }
}
cout << ansc << endl;
//cout << ans.size() << endl;
bool f = 0;
rep(i, N) {
if(!ansb[i]) continue;
if(f) cout << " ";
f = 1;
cout << i+1;
}
cout << endl;
return 0;
}
motxx