|
1 #include <iostream> 2 #include <cstdio> 3 #include <cstring> 4 #include <vector> 5 using namespace std; 6data:image/s3,"s3://crabby-images/13de6/13de6130588e8a001331bf125b484ea2f97d951e" alt="" 7 const int N = 10000; 8 vector<int> a[N]; 9 int f[N], r[N]; 10data:image/s3,"s3://crabby-images/13de6/13de6130588e8a001331bf125b484ea2f97d951e" alt="" 11data:image/s3,"s3://crabby-images/f86b7/f86b7e502a0580d5e24db72fe38f81dda2bc052d" alt="" void DFS(int u, int dep) { 12 r[u] = dep; 13data:image/s3,"s3://crabby-images/db282/db282e9ea79ad6a7617774c9b676a45b33d46480" alt="" for(vector<int>::iterator it = a[u].begin(); it != a[u].end(); ++it) { 14 DFS(*it, dep+1); 15 } 16 } 17data:image/s3,"s3://crabby-images/13de6/13de6130588e8a001331bf125b484ea2f97d951e" alt="" 18 int main() 19data:image/s3,"s3://crabby-images/f86b7/f86b7e502a0580d5e24db72fe38f81dda2bc052d" alt="" data:image/s3,"s3://crabby-images/3ee79/3ee79ec5a9b7f3dd33bbbdc97980715db1aa9f00" alt="" { 20 int casenum, x, y; 21 int n; 22 scanf("%d", &casenum); 23data:image/s3,"s3://crabby-images/db282/db282e9ea79ad6a7617774c9b676a45b33d46480" alt="" for(int num = 0; num < casenum; num++) { 24 scanf("%d", &n); 25data:image/s3,"s3://crabby-images/db282/db282e9ea79ad6a7617774c9b676a45b33d46480" alt="" for(int j = 0; j < n; j++) { 26 a[j].clear(); 27 } 28 memset(f, -1, sizeof(f)); 29data:image/s3,"s3://crabby-images/db282/db282e9ea79ad6a7617774c9b676a45b33d46480" alt="" for(int i = 0; i < n-1; i++) { 30 scanf("%d%d", &x, &y); 31 a[x-1].push_back(y-1); 32 f[y-1] = x-1; 33 } 34 int i; 35data:image/s3,"s3://crabby-images/db282/db282e9ea79ad6a7617774c9b676a45b33d46480" alt="" for( i = 0; f[i] >= 0; i++) { 36 ; 37 } 38 cout << i << endl; 39 DFS(i, 0); 40 scanf("%d%d", &x, &y); 41 x--; y--; 42data:image/s3,"s3://crabby-images/db282/db282e9ea79ad6a7617774c9b676a45b33d46480" alt="" while(x != y) { 43data:image/s3,"s3://crabby-images/db282/db282e9ea79ad6a7617774c9b676a45b33d46480" alt="" if(r[x] > r[y]) { 44 x = f[x]; 45 } 46data:image/s3,"s3://crabby-images/db282/db282e9ea79ad6a7617774c9b676a45b33d46480" alt="" else { 47 y = f[y]; 48 } 49 } 50 printf("%d\n", x+1); 51 } 52 return 0; 53 }
|