java迷宫,java迷宫代码解析

本文目录一览:

head first java第24页的泳池迷宫,我做出来的和答案不一样

想了一个晚上才想出来,来简单答一下。

while(x<4)

空格不填

if(x<1)

填“a”,” “,

x=x-1

if(x<1)

填”noise”

if(x==1)

填”annoys”

if(x>1)

填”an”,” oyster”(这个词前面自带空格)

x=x+2

然后你们在补充一下格式就行啦!

JAVA机器人走迷宫的编程——急求!

深度优先的迷宫图算法。

N年前的老问题了。

10分不值得做。

java最新迷宫问题,英文原版求解答

import java.util.*;

import java.util.regex.*;

class MyPoint

{

public boolean visited=false;

public int parentRow=-1;

public int parentColumn=-1;

public int x;

public int y;

public MyPoint(){}

public MyPoint(int x,int y)

{

this.x=x;

this.y=y;

}

}

class Maze

{

String[][] maze;

final int WIDTH;

final int HEIGHT;

final int START_X=1;

final int START_Y=1;

final int END_X;

final int END_Y;

MyPoint[][] visited;

public Maze()

{

Scanner s=new Scanner(System.in);

WIDTH=s.nextInt();//输入迷宫宽度

END_Y=WIDTH-2;

HEIGHT=s.nextInt();//输入迷宫长度

END_X=HEIGHT-2;

maze=new String[HEIGHT][];

visited=new MyPoint[HEIGHT][];

s.nextLine();//清除输入的回车

for(int i=0;iHEIGHT;++i)//输入迷宫的每一行,每一行中的字符之间用空格隔开

{

String temp=s.nextLine();

maze[i]=temp.split(“\\s+”);

visited[i]=new MyPoint[WIDTH];

for(int j=0;jWIDTH;++j)

{

visited[i][j]=new MyPoint(i,j);

}

}

System.out.println(“input finish.”);

for(int i=0;iHEIGHT;++i)

{

System.out.println(Arrays.toString(maze[i]));

}

}

public boolean tomRun()

{

LinkedListMyPoint stack=new LinkedListMyPoint();

stack.push(visited[START_X][START_Y]);

visited[START_X][START_Y].visited=true;

boolean result=false;

while(!stack.isEmpty())

{

MyPoint t=stack.pop();

System.out.println(“pop point:”+t.x+” “+t.y+” value:”+maze[t.x][t.y]);

if(t.x==END_Xt.y==END_Y)

{

result=true;

break;

}

if(visited[t.x-1][t.y].visited==false!maze[t.x-1][t.y].equals(“W”))

{

stack.push(visited[t.x-1][t.y]);

visited[t.x-1][t.y].parentRow=t.x;

visited[t.x-1][t.y].parentColumn=t.y;

visited[t.x-1][t.y].visited=true;

}

if(visited[t.x+1][t.y].visited==false!maze[t.x+1][t.y].equals(“W”))

{

stack.push(visited[t.x+1][t.y]);

visited[t.x+1][t.y].parentRow=t.x;

visited[t.x+1][t.y].parentColumn=t.y;

visited[t.x+1][t.y].visited=true;

}

if(visited[t.x][t.y-1].visited==false!maze[t.x][t.y-1].equals(“W”))

{

stack.push(visited[t.x][t.y-1]);

visited[t.x][t.y-1].parentRow=t.x;

visited[t.x][t.y-1].parentColumn=t.y;

visited[t.x][t.y-1].visited=true;

}

if(visited[t.x][t.y+1].visited==false!maze[t.x][t.y+1].equals(“W”))

{

stack.push(visited[t.x][t.y+1]);

visited[t.x][t.y+1].parentRow=t.x;

visited[t.x][t.y+1].parentColumn=t.y;

visited[t.x][t.y+1].visited=true;

}

}

return result;

}

public void show(int x,int y)

{

if(visited[x][y].parentRow==-1)

{

System.out.println(“[“+x+”,”+y+”]”);

return;

}

show(visited[x][y].parentRow,visited[x][y].parentColumn);

System.out.println(“-“+”[“+x+”,”+y+”]”);

}

public static void main(String[] args) 

{

Maze m=new Maze();

if(m.tomRun())

{

System.out.println(“逃生路径如下:”);

m.show(m.END_X,m.END_Y);

}

else

System.out.println(“无法走出迷宫!”);

}

}

原创文章,作者:AMZG,如若转载,请注明出处:https://www.506064.com/n/145953.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
AMZG的头像AMZG
上一篇 2024-10-29 18:57
下一篇 2024-10-29 18:57

相关推荐

  • Python周杰伦代码用法介绍

    本文将从多个方面对Python周杰伦代码进行详细的阐述。 一、代码介绍 from urllib.request import urlopen from bs4 import Bea…

    编程 2025-04-29
  • Java JsonPath 效率优化指南

    本篇文章将深入探讨Java JsonPath的效率问题,并提供一些优化方案。 一、JsonPath 简介 JsonPath是一个可用于从JSON数据中获取信息的库。它提供了一种DS…

    编程 2025-04-29
  • java client.getacsresponse 编译报错解决方法

    java client.getacsresponse 编译报错是Java编程过程中常见的错误,常见的原因是代码的语法错误、类库依赖问题和编译环境的配置问题。下面将从多个方面进行分析…

    编程 2025-04-29
  • Python字符串宽度不限制怎么打代码

    本文将为大家详细介绍Python字符串宽度不限制时如何打代码的几个方面。 一、保持代码风格的统一 在Python字符串宽度不限制的情况下,我们可以写出很长很长的一行代码。但是,为了…

    编程 2025-04-29
  • Java腾讯云音视频对接

    本文旨在从多个方面详细阐述Java腾讯云音视频对接,提供完整的代码示例。 一、腾讯云音视频介绍 腾讯云音视频服务(Cloud Tencent Real-Time Communica…

    编程 2025-04-29
  • Java Bean加载过程

    Java Bean加载过程涉及到类加载器、反射机制和Java虚拟机的执行过程。在本文中,将从这三个方面详细阐述Java Bean加载的过程。 一、类加载器 类加载器是Java虚拟机…

    编程 2025-04-29
  • Java Milvus SearchParam withoutFields用法介绍

    本文将详细介绍Java Milvus SearchParam withoutFields的相关知识和用法。 一、什么是Java Milvus SearchParam without…

    编程 2025-04-29
  • Python基础代码用法介绍

    本文将从多个方面对Python基础代码进行解析和详细阐述,力求让读者深刻理解Python基础代码。通过本文的学习,相信大家对Python的学习和应用会更加轻松和高效。 一、变量和数…

    编程 2025-04-29
  • Java 8中某一周的周一

    Java 8是Java语言中的一个版本,于2014年3月18日发布。本文将从多个方面对Java 8中某一周的周一进行详细的阐述。 一、数组处理 Java 8新特性之一是Stream…

    编程 2025-04-29
  • Java判断字符串是否存在多个

    本文将从以下几个方面详细阐述如何使用Java判断一个字符串中是否存在多个指定字符: 一、字符串遍历 字符串是Java编程中非常重要的一种数据类型。要判断字符串中是否存在多个指定字符…

    编程 2025-04-29

发表回复

登录后才能评论