文章

9

粉丝

126

获赞

10

访问

25.6k

头像
最小公共双亲的变型题
P1654 北京邮电大学2019年机试题
发布于2023年3月14日 10:01
阅读数 2.6k

#include <bits/stdc++.h>
using namespace std;

typedef struct node{
	int parent;
	node(){
		parent=-1;
	}
}node;

int main(){
	int t,n,m,l,r;
	scanf("%d",&t);
	
	while(t--){
		node nod[10000];
		scanf("%d %d",&n,&m);
		for(int i=1;i<=n;i++){//建树
			scanf("%d %d",&l,&r);
			if(l!=-1) nod[l].parent=i;
			if(r!=-1) nod[r].parent=i;
		}

		while(m--){
			scanf("%d %d",&l,&r);
			vector<int> lv,rv;//分别存到根节点的路径

			while(l!=-1){
				lv.push_back(l);
				l=nod[l].parent;
			}
			while(r!=-1){
				rv.push_back(r);
				r=nod[r].parent;
			}
			
			int i=lv.size()-1,j=rv.size()-1;
			
			for(;i>=0,j>=0;i--,j--){
				if(lv[i]!=rv[j]){//找最小公共双亲
					break;
				}
			}
			cout<<i+j+2<<endl;//找出来的数字规律

//			cout<<"这是lv:";
//			for(int a=0;a<lv.size();a++) cout<<lv[a]<<" ";
//			cout<<endl<<"这是rv:";
//			for(int a=0;a<rv.size();a++) cout<<rv[a]<...
登录查看完整内容


登录后发布评论

暂无评论,来抢沙发