当前位置:首页 > 题解目录 > 正文内容

【题解】校运会

亿万年的星光3年前 (2023-04-13)题解目录2296

【题目描述】

校运会上,一共有N个参赛选手,已知N个选手的名字。然后老师告诉你M句话,话的内容是学生A与学生B在同一组里。如果学生A与学生B在同一组里,学生B与学生C也在同一组里,就说明学生A与学生C在同一组。

然后老师问你K句话,即学生X和学生Y是否在同一组里。若是,输出Yes,否则输出No。

22×104参赛选手。(尼玛全校学生都没这么多吧)

【输入描述】

第一行N和M。

接下来N行输入每一个同学的名字。

再往下M行每行输入两个名字,且保证这两个名字都在上面 N行中出现过,表示这两个参赛选手在同一个组里。

接下来输入K。

最后输入K个老师的询问。

【输出描述】

对于每一个循环,输出Yes或者No

【样例输入】

10 6
Jack
Mike
ASDA
Michel
brabrabra
HeHe
HeHE
papapa
HeY
Obama
Jack Obama
HeHe HeHE
brabrabra HeHe
Obama ASDA
papapa Obama
Obama HeHE
3
Mike Obama
HeHE Jack
papapa brabrabra

【样例输出】

No.
Yes.
Yes.

【数据范围】

2<=N<=2*10^4
1<=M<=10^6
1<=K<=10^6

【题目分析】

  • 并查集题目,问题就是如何表示字符串这个问题。


我们可以定义一个结构体,参考如下:

struct node{	
	string s; //姓名 
	int num;	//编号 
};

用s表示姓名,用num表示编号,然后左侧的圆圈表示当前这个人的下标。

那么,在以前中并查集中,我们的指向关系中,我们是p[4]=9,那么在结构体中,就是 p[x].num=p[y].num

通过上面这种指向关系确定父级和子级




【参考答案:结构体】

#include<bits/stdc++.h>
using namespace std;
int n,m,k;
struct node{	
	string s;     //姓名 
	int num;	//编号 
};
node p[20005]; 


//查找函数 
int find(int n){	 
	if(p[n].num==n) 
		return p[n].num;
	else  
		return 	p[n].num=find(p[n].num);

}
void merge(int a,int b){	//合并并查集 
	int fa=find(a);
	int fb=find(b);		
	if(fa==fb) return ;
	else p[fa].num=p[fb].num;
	return;
}
//查找这个名字 
int sfind(string a){
	for(int i=1;i<=n;i++){
		if(a==p[i].s) return i;
	}
}
int main(){
	cin>>n>>m;]
	//输入以及初始化 
	for(int i=1;i<=n;i++){
		cin>>p[i].s;	 
		p[i].num=i;
	}	
	//查找并合并 
	for(int i=1;i<=m;i++){
		string x,y;	
		cin>>x>>y;
		if(find(sfind(x))!=find(sfind(y))){	//查找两个名字
			merge(sfind(x),sfind(y));		//合并 
		}
	} 
	cin>>k;	 
	//k次询问 
	for(int i=1;i<=k;i++){	
		string x1,y1;
		cin>>x1>>y1;
		//查找两个名字
		if(find(sfind(x1))==find(sfind(y1))){	
			cout<<"Yes."<<endl;			
		}else {
			cout<<"No."<<endl;		 
		}
	}
	return 0;	
}


    扫描二维码推送至手机访问。

    版权声明:本文由青少年编程知识记录发布,如需转载请注明出处。

    分享给朋友:

    相关文章

    公路(road)

    公路(road)

    【题目描述】小苞准备开着车沿着公路自驾。公路上一共有n个站点,编号为从1 到n。其中站点i与站点i+1 的距离为vi公里。公路上每个站点都可以加油,编号为i 的站点一升油的价格为a...

    【题解】最低通行费

    【题目描述】一个商人穿过一个N×N的正方形的网格,去参加一个非常重要的商务活动。他要从网格的左上角进,右下角出。每穿越中间1个小方格,都要花费1个单位时间。商人必须在(2N-1)个单位时间穿越出去。而...

    剪刀石头布

    【题目描述】石头剪子布,是一种猜拳游戏。起源于中国,然后传到日本、朝鲜等地,随着亚欧贸易的不断发展它传到了欧洲,到了近现代逐渐风靡世界。简单明了的规则,使得石头剪子布没有任何规则漏洞可钻,单次玩法比拼...

    【题解】分糖果问题

    【题解】分糖果问题

    【题目描述】一群孩子做游戏,现在请你根据游戏得分来发糖果,要求如下:每个孩子不管得分多少,起码分到一个糖果。任意两个相邻的孩子之间,得分较多的孩子必须拿多一些糖果。(若相同则无此限制)给定一个数组 a...

    【题解】母舰

    【题目描述】在小A的星际大战游戏中,一艘强力的母舰往往决定了一场战争的胜负。一艘母舰的攻击力是普通的MA(Mobile  Armor)无法比较的。 对于一艘母舰而言,它是由若干个攻击系统和若...

    【题解】愤怒的牛

    【题目描述】农夫 John 建造了一座很长的畜栏,它包括N(2<=N<100000)个隔间,这些小隔间依次编号为x1,x2,...xn(0<=xi<=1000000000)。但...