結果
問題 | No.416 旅行会社 |
ユーザー |
![]() |
提出日時 | 2016-08-26 23:09:42 |
言語 | C++14 (gcc 13.3.0 + boost 1.87.0) |
結果 |
AC
|
実行時間 | 426 ms / 4,000 ms |
コード長 | 1,836 bytes |
コンパイル時間 | 2,138 ms |
コンパイル使用メモリ | 187,496 KB |
実行使用メモリ | 37,988 KB |
最終ジャッジ日時 | 2024-12-14 19:48:33 |
合計ジャッジ時間 | 6,791 ms |
ジャッジサーバーID (参考情報) |
judge4 / judge3 |
(要ログイン)
ファイルパターン | 結果 |
---|---|
other | AC * 21 |
ソースコード
#include <bits/stdc++.h>using namespace std;#define _p(...) (void)printf(__VA_ARGS__)#define forr(x,arr) for(auto&& x:arr)#define _overload3(_1,_2,_3,name,...) name#define _rep2(i,n) _rep3(i,0,n)#define _rep3(i,a,b) for(int i=int(a);i<int(b);++i)#define rep(...) _overload3(__VA_ARGS__,_rep3,_rep2,)(__VA_ARGS__)#define _rrep2(i,n) _rrep3(i,0,n)#define _rrep3(i,a,b) for(int i=int(b)-1;i>=int(a);i--)#define rrep(...) _overload3(__VA_ARGS__,_rrep3,_rrep2,)(__VA_ARGS__)#define ALL(x) (x).begin(), (x).end()#define BIT(n) (1LL<<(n))#define SZ(x) ((int)(x).size())#define fst first#define snd secondtypedef long long ll;typedef vector<int> vi;typedef vector<vi> vvi;typedef pair<int,int> pii;typedef vector<pii> vpii;const int inf = 1e9;void Main() {int N, M, Q;scanf("%d%d%d", &N, &M, &Q);vector<vpii> E(N);vector<map<int, int>> ma(N);rep(i, M) {int u, v;scanf("%d%d", &u, &v);u--; v--;ma[u][v] = SZ(E[u]);ma[v][u] = SZ(E[v]);E[u].emplace_back(v, inf);E[v].emplace_back(u, inf);}rep(i, Q) {int c, d;scanf("%d%d", &c, &d);c--; d--;assert(E[c][ma[c][d]].fst == d);assert(E[d][ma[d][c]].fst == c);E[c][ma[c][d]].snd = i;E[d][ma[d][c]].snd = i;}// 大きい方が偉いvi D(N, -1);priority_queue<pii> q;D[0] = inf;q.emplace(inf, 0);while (!q.empty()) {int c, v;tie(c, v) = q.top(); q.pop();if (D[v] > c) continue;for (auto&& nex : E[v]) {int nv = nex.first;int nc = min(c, nex.second);if (D[nv] < nc) {D[nv] = nc;q.emplace(nc, nv);}}}rep(i, 1, N) {if (D[i] == inf) {puts("-1");}else {_p("%d\n", D[i]+1);}}}int main() { cin.tie(0); ios::sync_with_stdio(false); Main(); return 0; }