蓝桥杯— 合根植物(并查集)

题目:在这里插入图片描述
在这里插入图片描述
在这里插入图片描述
思路:此题运用并查集,链接:https://www.cnblogs.com/xzxl/p/7226557.html

import java.util.HashSet;
import java.util.Scanner;
import java.util.Set;

public class Main{
	static int[] pre;
	public static void main(String[] args) {
		Scanner in=new Scanner(System.in);
		int m=in.nextInt();
		int n=in.nextInt();
		int k=in.nextInt();
		pre=new int[n*m+1];
		for(int i=1;i<=m*n;i++) {
			pre[i]=i;//初始化
		}
		for(int i=0;i<k;i++) {
			int a=in.nextInt();
			int b=in.nextInt();
			union(a,b);
		}
		in.close();
		
		Set<Integer> set=new HashSet<Integer>();
		for(int i=1;i<=m*n;i++) {
			set.add(find(i));
		}
		System.out.println(set.size());
	}
	public static int find(int x) {
		int a=x;
		//寻找根节点
		while(pre[a]!=a)
			a=pre[a];
		//缩短路径
		int b=x;
		while(pre[b]!=a) {
			int t=pre[b];
			pre[b]=a;
			b=t;
		}
		return a;
	}
	
	public static void union(int x,int y) {
		int px=find(x);
		int py=find(y);
		if(px!=py) {
			pre[px]=py;
		}
	}
}

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值