并查集

并查集是一种特殊的数据结构,用于判别哪些元素属于同一类别。

它包括两个操作,即规约合并union以及寻找类别find。

下面是一道题目:

百度全体员工玩分组游戏,前面五分钟大家分头找队友,并将每个人找到的队友信息汇报给主持人,如果AB是队友,BC是队友,那么AC也是队友;接着主持人不断地随机抽取两个人,希望判断二者是否为队友。请设计一个计算机程序辅助主持人判断两个人是否为队友。

对于这个题目,我们只需算出,哪些队员属于某一类即可。这就是并查集的典型运用。

package com.Algorithm.DisjointSet;
import java.util.*;
/*
 * author:Tammy Pi
 * function:并查集
 */
public class DisjointSet {

	private String[] people={"小明","小王","小军","小丽","小李"};
	private int[] s=new int[people.length];
	
	//构造函数,初始化
	public DisjointSet()
	{
		for(int i=0;i<s.length;i++)
		{
			s[i]=-1;
		}
	}//DisjointSet

    //归并
	public void union(int i,int j)
	{
		if(s[i]==-1&&s[j]==-1)
		{
			s[i]=Math.max(i,j);
			s[j]=Math.max(i,j);
		}
		else if(s[i]!=-1)
		{
			s[j]=s[i];
		}
		else if(s[j]!=-1)
		{
			s[i]=s[j];
		}
		else
		{
			int temp=Math.max(s[i],s[j]);
			s[i]=temp;
			s[j]=temp;
		}
	}
	//寻找
	public int find(int i)
	{
		if(s[i]<0)
		{
			return i;
		}
		return s[i];
	}
	public int[] getS()
	{
		return this.s;
	}
	public String[] getPeople()
	{
		return this.people;
	}
	public static void main(String[] args)
	{
		DisjointSet disjoint=new DisjointSet();
		//<小明,小王>
		disjoint.union(0,1);
		//<小军,小王>
		disjoint.union(2,1);
		//<小丽,小李>
        disjoint.union(3,4);
        
        for(int i=0;i<disjoint.getS().length;i++)
        {
        	System.out.println(disjoint.getPeople()[i]+" "+"属于类别:"+disjoint.getS()[i]);
        }
	}
}
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值