#include using namespace std; #define int long long typedef vectorvint; typedef pairpint; typedef vectorvpint; #define rep(i,n) for(int i=0;i<(n);i++) #define reps(i,f,n) for(int i=(f);i<(n);i++) #define all(v) (v).begin(),(v).end() #define each(it,v) for(__typeof((v).begin()) it=(v).begin();it!=(v).end();it++) #define pb push_back #define fi first #define se second templateinline void chmin(A &a,B b){if(a>b)a=b;} templateinline void chmax(A &a,B b){if(avalue; } int operator[](int k) { node *res = immutable_get(k, root, 0, h); return res != nullptr ? res->value : -1; } private: struct node { node *ch[8] = {}; int value = -1; }; int h; node *root = nullptr; node *immutable_get(int a, node *x, int l, int d) { if (x == nullptr) return x; if (d == 0) return x; int id = (a - l) >> (d - 3); return immutable_get(a, x->ch[id], l + (id << (d - 3)), d - 3); } pair mutable_get(int a, node *x, int l, int d) { x = x != nullptr ? new node(*x) : new node(); if (d == 0) return make_pair(x, x); int id = (a - l) >> (d - 3); auto p = mutable_get(a, x->ch[id], l + (id << (d - 3)), d - 3); x->ch[id] = p.first; return make_pair(x, p.second); } }; // root: O(logN loglogN) // merge: O(logN loglogN) struct UnionFind { Array uf; UnionFind() : uf(0) {} UnionFind(int n) : uf(n) {} int root(int x) { int nd = uf[x]; if (nd < 0) return x; return root(nd); } void merge(int x, int y) { x = root(x); y = root(y); if (x == y) return; int *u = uf.mutable_get(x); int *v = uf.mutable_get(y); if (-*u < -*v) swap(u, v), swap(x, y); *u += *v; *v = x; } int size(int x) { return -uf[root(x)]; } int query(int x, int y) { x = root(x); y = root(y); if (x == y) { return -uf[x]; } else { return -uf[x] - uf[y]; } } }; int N,M,Q; int C[222222],D[222222]; signed main(){ scanf("%lld%lld%lld",&N,&M,&Q); vpint es; rep(i,M){ int a,b; scanf("%lld%lld",&a,&b); a--;b--; if(a>b)swap(a,b); es.pb(pint(a,b)); } sort(all(es)); vint used(M,0); rep(i,Q){ scanf("%lld%lld",&C[i],&D[i]); C[i]--;D[i]--; if(C[i]>D[i])swap(C[i],D[i]); int tmp=lower_bound(all(es),pint(C[i],D[i]))-es.begin(); used[tmp]=true; } vectorufs(Q+1); UnionFind uf(N); rep(i,M)if(!used[i])uf.merge(es[i].fi,es[i].se); ufs[Q]=uf; for(int i=Q-1;i>=0;i--){ uf.merge(C[i],D[i]); ufs[i]=uf; } reps(i,1,N){ int lb=-1,ub=Q+1; while(ub-lb>1){ int mid=(ub+lb)/2; if(ufs[mid].root(0)==ufs[mid].root(i)){ lb=mid; } else{ ub=mid; } } if(ub==Q+1)puts("-1"); else printf("%lld\n",ub); } return 0; }