結果

問題 No.92 逃走経路
ユーザー motxx
提出日時 2014-12-07 20:23:03
言語 C++11(廃止可能性あり)
(gcc 13.3.0)
結果
RE  
実行時間 -
コード長 2,461 bytes
コンパイル時間 1,777 ms
コンパイル使用メモリ 182,532 KB
実行使用メモリ 38,152 KB
最終ジャッジ日時 2024-06-11 16:29:05
合計ジャッジ時間 10,723 ms
ジャッジサーバーID
(参考情報)
judge1 / judge3
このコードへのチャレンジ
(要ログイン)
ファイルパターン 結果
sample RE * 2
other AC * 4 RE * 14
権限があれば一括ダウンロードができます

ソースコード

diff #
プレゼンテーションモードにする

#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;
struct EDGE {
int u, v, c;
bool operator < (EDGE const& e) const {
return c < e.c;
}
};
struct Edge {
// int u, v, c;
int to, cost;
/*
bool operator < (Edge const& e) const {
return c < e.c;
}
*/
};
typedef vector<Edge> Edges;
typedef vector<Edges> Graph;
int const INF = 1<<29;
Graph g;
vector<int> d;
vector<set<int> > vlist;
int N, M, K;
set<int> ans;
bool memo[110][1100]; //[idx][depth]
void dfs(int idx, int depth) {
// cerr << idx << endl;
if(memo[idx][depth]) return;
if(depth == K) {
// cerr << "inserted: " << idx << endl;
ans.insert(idx);
}
memo[idx][depth] = 1;
rep(i, g[idx].size()) {
Edge& e = g[idx][i];
if(!vlist[depth].count(e.to)) continue;
if(d[depth] != e.cost) continue;
dfs(e.to, depth+1);
}
}
int main() {
cin >> N >> M >> K;
vector<EDGE> es(M);
g.resize(N);
rep(i, M) {
int a, b, c; cin >> a >> b >> c; a--, b--;
es[i].u = a, es[i].v = b, es[i].c = c;
//g[a].push_back((Edge){b, c});
//g[b].push_back((Edge){a, c});
}
d.resize(K);
rep(i, K) cin >> d[i];
sort(es.begin(), es.end());
vector<vector<EDGE> > v(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);
}
}
vlist.resize(K);
// set<pair<int, int> > st;
rep(i, K) {
rep(j, v[i].size()) {
vlist[i].insert(v[i][j].u);
vlist[i].insert(v[i][j].v);
//vlist[i].push_back(v[i][j].u);
//vlist[i].push_back(v[i][j].v);
// if(!st.count(make_pair(v[i][j].u, v[i][j].v))) {
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});
}
/*
sort(vlist[i].begin(), vlist[i].end());
vlist[i].erase(unique(vlist[i].begin(), vlist[i].end()), vlist[i].end());
*/
}
for(auto e: vlist[0]) {
dfs(e, 0);
// cerr << "---\n";
}
cout << ans.size() << endl;
bool f = 0;
for(auto e: ans) {
if(f) cout << " ";
f = 1;
cout << e+1;
}
cout << endl;
return 0;
}
הההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההה
XXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXX
0