利用加权quick-union来进行判断连连看

2024-01-24 22:48

本文主要是介绍利用加权quick-union来进行判断连连看,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

代码:

package Algorithm;import java.util.Scanner;public class SeriesLook {
/** 连连看进行判断是否连接* 利用加权quick——union来进行判断是否连接* 存储图的是一个二维数组,首先进行初始* 思路:首先要利用qu中的性质来判断是否是相连的,性质则是每两个点之间要先连,则如果是零就要初始值,在构造函数中已经将其初始值了* 		但是进行判断的时候还需要初始值,就是一个点判断是否与隔壁点相连,则需要判断四个点,才可以确认,则我们可以初始值左边,上边,右边* 		然后再判断三个点进行,即为上点与中心点是否为0,左点,右点也是这样。如果满足,则将其进行比较根节点* 		最后输出yes还是no* */private static int[][] data;private static int[][] id;private int[][] num;private int count;public SeriesLook(int N,int M) {//横竖的值count = N;//记录初始值的分量id = new int[N][M];num = new int[N][M];for(int i =0;i<N;i++) {for(int j=0;j<M;j++) if(data[i][j]==0)//如果是0就可以走{id[i][j]=i*100+j;//赋值为原值num[i][j]=1;}}}public int count() {return count;//返回长度}public boolean connected(int p,int q) {return find(p)==find(q);}public int find(int p) {int i = p/100;//获取横坐标int j = p%100;//获取纵坐标while(id[i][j]!=p) {int temp=id[i][j];//下一个节点i = temp/100;j = temp%100;p = temp;}return p;//为最后的根节点}public void union(int p,int q) {//进行判断是否进行创新新节点int i=find(p);//找寻其节点int j = find(q);if(i==j) return ;if(num[i/100][i%100]<num[j/100][j%100]) {//判断谁的子节点多,多的话则将其设为大树id[i/100][i%100]=j;//头节点指向j的头几点num[j/100][j%100]+=num[i/100][i%100];}else {id[j/100][j%100]=i;num[i/100][i%100]+=num[j/100][j%100];}count--;}public static void main(String[] args) {// TODO Auto-generated method stubScanner scanner = new Scanner(System.in);System.out.println("输入n.m");int n = scanner.nextInt();//横坐标int m = scanner.nextInt();//纵坐标System.out.println("输入数据:");data = new int[n][m];for(int i =0;i<n;i++)for(int j=0;j<m;j++)data[i][j]=scanner.nextInt();System.out.println("输入要判断的数值:");int a = scanner.nextInt();int b = scanner.nextInt();int c = scanner.nextInt();int d = scanner.nextInt();data[a][b]= 0;data[c][d] = 0;SeriesLook sl = new SeriesLook(n,m);//初始值,必须两个点来进行判才可以判断是否连接,所以需要初始值for(int i =1;i<m;i++) {//初始值横坐标if(data[0][i]==0&&data[0][i-1]==0) {sl.union(i, i-1);//首行两个点则进行判断}}for(int i =1;i<n;i++) {//纵坐标if(data[i][0]==0&&data[i-1][0]==0) {sl.union(i*100, (i-1)*100);}}for(int i=1;i<n;i++)for(int j=1;j<m;j++) {//上左右比较System.out.println("+"+1%100);if(data[i-1][j]==0&&data[i][j]==0)//上比较sl.union((i-1)*100+j, i*100+j);if(data[i][j-1]==0&&data[i][j]==0)//左比较sl.union(i*100+j-1, i*100+j);}for(int i =0;i<n;i++) {for(int j = 0;j<m;j++) {System.out.print(id[i][j]+" ");}System.out.println();}if(sl.connected(a*100+b, c*100+d))System.out.println("yes");elseSystem.out.println("no");}}

这篇关于利用加权quick-union来进行判断连连看的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/641261

相关文章

Python调用Orator ORM进行数据库操作

《Python调用OratorORM进行数据库操作》OratorORM是一个功能丰富且灵活的PythonORM库,旨在简化数据库操作,它支持多种数据库并提供了简洁且直观的API,下面我们就... 目录Orator ORM 主要特点安装使用示例总结Orator ORM 是一个功能丰富且灵活的 python O

Nginx设置连接超时并进行测试的方法步骤

《Nginx设置连接超时并进行测试的方法步骤》在高并发场景下,如果客户端与服务器的连接长时间未响应,会占用大量的系统资源,影响其他正常请求的处理效率,为了解决这个问题,可以通过设置Nginx的连接... 目录设置连接超时目的操作步骤测试连接超时测试方法:总结:设置连接超时目的设置客户端与服务器之间的连接

Java判断多个时间段是否重合的方法小结

《Java判断多个时间段是否重合的方法小结》这篇文章主要为大家详细介绍了Java中判断多个时间段是否重合的方法,文中的示例代码讲解详细,感兴趣的小伙伴可以跟随小编一起学习一下... 目录判断多个时间段是否有间隔判断时间段集合是否与某时间段重合判断多个时间段是否有间隔实体类内容public class D

使用 sql-research-assistant进行 SQL 数据库研究的实战指南(代码实现演示)

《使用sql-research-assistant进行SQL数据库研究的实战指南(代码实现演示)》本文介绍了sql-research-assistant工具,该工具基于LangChain框架,集... 目录技术背景介绍核心原理解析代码实现演示安装和配置项目集成LangSmith 配置(可选)启动服务应用场景

如何通过海康威视设备网络SDK进行Java二次开发摄像头车牌识别详解

《如何通过海康威视设备网络SDK进行Java二次开发摄像头车牌识别详解》:本文主要介绍如何通过海康威视设备网络SDK进行Java二次开发摄像头车牌识别的相关资料,描述了如何使用海康威视设备网络SD... 目录前言开发流程问题和解决方案dll库加载不到的问题老旧版本sdk不兼容的问题关键实现流程总结前言作为

SpringBoot中使用 ThreadLocal 进行多线程上下文管理及注意事项小结

《SpringBoot中使用ThreadLocal进行多线程上下文管理及注意事项小结》本文详细介绍了ThreadLocal的原理、使用场景和示例代码,并在SpringBoot中使用ThreadLo... 目录前言技术积累1.什么是 ThreadLocal2. ThreadLocal 的原理2.1 线程隔离2

Python利用PIL进行图片压缩

《Python利用PIL进行图片压缩》有时在发送一些文件如PPT、Word时,由于文件中的图片太大,导致文件也太大,无法发送,所以本文为大家介绍了Python中图片压缩的方法,需要的可以参考下... 有时在发送一些文件如PPT、Word时,由于文件中的图片太大,导致文件也太大,无法发送,所有可以对文件中的图

如何使用Spring boot的@Transactional进行事务管理

《如何使用Springboot的@Transactional进行事务管理》这篇文章介绍了SpringBoot中使用@Transactional注解进行声明式事务管理的详细信息,包括基本用法、核心配置... 目录一、前置条件二、基本用法1. 在方法上添加注解2. 在类上添加注解三、核心配置参数1. 传播行为(

Java实战之自助进行多张图片合成拼接

《Java实战之自助进行多张图片合成拼接》在当今数字化时代,图像处理技术在各个领域都发挥着至关重要的作用,本文为大家详细介绍了如何使用Java实现多张图片合成拼接,需要的可以了解下... 目录前言一、图片合成需求描述二、图片合成设计与实现1、编程语言2、基础数据准备3、图片合成流程4、图片合成实现三、总结前

在Mysql环境下对数据进行增删改查的操作方法

《在Mysql环境下对数据进行增删改查的操作方法》本文介绍了在MySQL环境下对数据进行增删改查的基本操作,包括插入数据、修改数据、删除数据、数据查询(基本查询、连接查询、聚合函数查询、子查询)等,并... 目录一、插入数据:二、修改数据:三、删除数据:1、delete from 表名;2、truncate