#include using namespace std; int x,y,n,m,q,c1=0,c2=0,h[100005],hd[100005],f[100005],ans[100005]; struct nd{ int u,v,nxt,num,tg; }e1[400005],e2[400005]; int fd(int q){ if(f[q]==q) return q; return fd(f[q]); } int fans(int q){ if(f[q]==q&&q==1) return -1; if(f[q]==q) return 0; if(ans[q]) return ans[q]; return ans[q]=fans(f[q]); } void jb(int u,int v,int ad){ if(!ad){ e1[++c1].u=u; e1[c1].v=v; e1[c1].nxt=h[u]; h[u]=c1; }else{ e2[++c2].u=u; e2[c2].v=v; e2[c2].nxt=hd[u]; hd[u]=c2; e2[c2].num=ad; } } bool cmp(nd a,nd b){ if(a.u==b.u) return a.vb.num; } signed main(){ // freopen("evacuate.in","r",stdin); // freopen("evacuate.out","w",stdout); cin>>n>>m>>q; for(int i=1;i<=m;i++){ scanf("%d%d",&x,&y); jb(x,y,0); jb(y,x,0); }for(int i=1;i<=q;i++){ scanf("%d%d",&x,&y); jb(x,y,i); jb(y,x,i); }sort(e1+1,e1+m*2+1,cmp); sort(e2+1,e2+q*2+1,cmp); for(int i=1,j=1;i<=q*2;i++,j++){ if(e1[j].u==e2[i].u&&e1[j].v==e2[i].v) e1[j].tg=e1[j].tg=0; else{ while(e1[j].u!=e2[i].u||e1[j].v!=e2[i].v){ e1[j].tg=1; j++; }e1[j].tg=0; } }for(int i=1;i<=n;i++) f[i]=i; for(int i=1;i<=n;i++) ans[i]=0; for(int i=1;i<=m*2;i++){ if(e1[i].tg){ int u=e1[i].u,v=e1[i].v,fu=fd(u),fv=fd(v),f1=fd(1); if(fu==f1||fv==f1) ans[u]=ans[v]=-1; f[fu]=fv; } }sort(e2+1,e2+q*2+1,cmp2); for(int i=1;i<=q*2;i++){ int u=e2[i].u,v=e2[i].v,fu=fd(u),fv=fd(v),f1=fd(1); // if(u==2||v==2) cout<