java实现从迷宫寻找出路算法(广度优先搜索)

2024-06-01 01:48

本文主要是介绍java实现从迷宫寻找出路算法(广度优先搜索),希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

import com.alibaba.fastjson.JSONObject;
import java.util.ArrayDeque;
/**
* Created by Administrator on 2017/7/12.
*/
public class ScopeSearchFirst {
public static void main(String... args) {
int[][]  a = new int[51][51];//初始化为0
System.out.println(JSONObject.toJSONString(a));
int[][]  book = new int[51][51];//初始化为0
int[][] next = {{0,1},{0,-1},{1,0},{-1,0}};
for(int i=0;i<=50;i++) {
for (int j = 0; j < 50; j++) {
if (i == 0 && j == 0) {
continue;
}
if (j == i) {
a[i][j] = 1;//设置为障碍物
break;
}
}
}
System.out.println("初始化后的结果:");
for(int i=0;i<50;i++)
for(int j=0;j<50;j++)
if(j==49)
System.out.println();
else
System.out.print(a[i][j]);
int startx = 0;
int starty = 0;
int p = 35;
int q = 23;
ArrayDequequeue = new ArrayDeque();
Note note = new Note();
note.setX(startx);
note.setY(starty);
note.setS(0);
queue.addLast(note);
book[0][0]=1;
int flag = 0;
int tx=0;
int ty=0;
while (!queue.isEmpty()) {
for (int k = 0; k <= 3; k++) {
tx = queue.getFirst().getX()+next[k][0];
ty = queue.getFirst().getY()+next[k][1];
if(tx<0||tx>=50||ty<0||ty>=50)
continue;
if(a[tx][ty]==0&&book[tx][ty]==0){
book[tx][ty]=1;
Note newNote = new Note();
newNote.setX(tx);
newNote.setY(ty);
newNote.setF(queue.getFirst());
newNote.setS(queue.getFirst().getS()+1);
queue.addLast(newNote);
}
if(tx==p&&ty==q){
flag=1;
break;
}
}
if(flag==1)
break;
queue.removeFirst();
}
System.out.println("最短距离:"+queue.getLast().getS());
}
static class Note{
private int x;
private int y;
private int s;
private Note f;
public int getX() {
return x;
}
public void setX(int x) {
this.x = x;
}
public int getY() {
return y;
}
public void setY(int y) {
this.y = y;
}
public int getS() {
return s;
}
public void setS(int s) {
this.s = s;
}
public Note getF() {
return f;
}
public void setF(Note f) {
this.f = f;
}
}
}

这篇关于java实现从迷宫寻找出路算法(广度优先搜索)的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



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

相关文章

Python实现AVIF图片与其他图片格式间的批量转换

《Python实现AVIF图片与其他图片格式间的批量转换》这篇文章主要为大家详细介绍了如何使用Pillow库实现AVIF与其他格式的相互转换,即将AVIF转换为常见的格式,比如JPG或PNG,需要的小... 目录环境配置1.将单个 AVIF 图片转换为 JPG 和 PNG2.批量转换目录下所有 AVIF 图

Java Predicate接口定义详解

《JavaPredicate接口定义详解》Predicate是Java中的一个函数式接口,它代表一个判断逻辑,接收一个输入参数,返回一个布尔值,:本文主要介绍JavaPredicate接口的定义... 目录Java Predicate接口Java lamda表达式 Predicate<T>、BiFuncti

Pydantic中model_validator的实现

《Pydantic中model_validator的实现》本文主要介绍了Pydantic中model_validator的实现,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价... 目录引言基础知识创建 Pydantic 模型使用 model_validator 装饰器高级用法mo

Spring Security基于数据库的ABAC属性权限模型实战开发教程

《SpringSecurity基于数据库的ABAC属性权限模型实战开发教程》:本文主要介绍SpringSecurity基于数据库的ABAC属性权限模型实战开发教程,本文给大家介绍的非常详细,对大... 目录1. 前言2. 权限决策依据RBACABAC综合对比3. 数据库表结构说明4. 实战开始5. MyBA

AJAX请求上传下载进度监控实现方式

《AJAX请求上传下载进度监控实现方式》在日常Web开发中,AJAX(AsynchronousJavaScriptandXML)被广泛用于异步请求数据,而无需刷新整个页面,:本文主要介绍AJAX请... 目录1. 前言2. 基于XMLHttpRequest的进度监控2.1 基础版文件上传监控2.2 增强版多

Spring Security方法级安全控制@PreAuthorize注解的灵活运用小结

《SpringSecurity方法级安全控制@PreAuthorize注解的灵活运用小结》本文将带着大家讲解@PreAuthorize注解的核心原理、SpEL表达式机制,并通过的示例代码演示如... 目录1. 前言2. @PreAuthorize 注解简介3. @PreAuthorize 核心原理解析拦截与

一文详解JavaScript中的fetch方法

《一文详解JavaScript中的fetch方法》fetch函数是一个用于在JavaScript中执行HTTP请求的现代API,它提供了一种更简洁、更强大的方式来处理网络请求,:本文主要介绍Jav... 目录前言什么是 fetch 方法基本语法简单的 GET 请求示例代码解释发送 POST 请求示例代码解释

Java图片压缩三种高效压缩方案详细解析

《Java图片压缩三种高效压缩方案详细解析》图片压缩通常涉及减少图片的尺寸缩放、调整图片的质量(针对JPEG、PNG等)、使用特定的算法来减少图片的数据量等,:本文主要介绍Java图片压缩三种高效... 目录一、基于OpenCV的智能尺寸压缩技术亮点:适用场景:二、JPEG质量参数压缩关键技术:压缩效果对比

Java调用C++动态库超详细步骤讲解(附源码)

《Java调用C++动态库超详细步骤讲解(附源码)》C语言因其高效和接近硬件的特性,时常会被用在性能要求较高或者需要直接操作硬件的场合,:本文主要介绍Java调用C++动态库的相关资料,文中通过代... 目录一、直接调用C++库第一步:动态库生成(vs2017+qt5.12.10)第二步:Java调用C++

Redis分片集群的实现

《Redis分片集群的实现》Redis分片集群是一种将Redis数据库分散到多个节点上的方式,以提供更高的性能和可伸缩性,本文主要介绍了Redis分片集群的实现,具有一定的参考价值,感兴趣的可以了解一... 目录1. Redis Cluster的核心概念哈希槽(Hash Slots)主从复制与故障转移2.