溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務(wù)條款》

Java基于深度優(yōu)先遍歷的隨機(jī)迷宮生成算法

發(fā)布時間:2020-10-14 05:06:47 來源:腳本之家 閱讀:152 作者:嚴(yán)洋羽 欄目:編程語言

這兩天因為要做一個隨機(jī)的地圖生成系統(tǒng),所以一直在研究隨機(jī)迷宮生成算法,好吧,算是有一點小小的成果。

隨機(jī)迷宮生成我自己的理解簡而言之分為以下幾步:

1、建立一張地圖,我用的二維數(shù)組表示,地圖上全是障礙物。然后再創(chuàng)建一個用來表示每個格子是否被訪問過的二維數(shù)組。再創(chuàng)建一個用來表示路徑的棧結(jié)構(gòu)。

2、隨機(jī)選擇地圖上的一點,呃為了方便我初始點直接取的是左上角即坐標(biāo)表示為0,0的格子。終點的話因為不涉及到交互就暫時沒有。

3、查找當(dāng)前格子的鄰接格(注意,這里的鄰接格子都是還未被訪問的,下面的代碼里有寫)。隨機(jī)選擇一個鄰接格子為下一格,當(dāng)前格移動到下一格,標(biāo)記當(dāng)前格為已訪問,將當(dāng)前格壓入路徑棧中。一直重復(fù)第三步操作。

4、在第三步操作中,如果當(dāng)前格子不存在可訪問的鄰接格,則將棧頂?shù)脑貜棾?,即退回上一步操作,如果棧為空,則結(jié)束程序,打印結(jié)果。

附上結(jié)果和源碼,這是基于JAVA控制臺來寫的。

Java基于深度優(yōu)先遍歷的隨機(jī)迷宮生成算法

Java基于深度優(yōu)先遍歷的隨機(jī)迷宮生成算法

package maze;
import java.util.ArrayList;
import java.util.List;
import java.util.Random;
import java.util.Stack;
public class Maze 
{
 int len = 11; //迷宮長度
 int wid = 11; //迷宮寬度
 char wall = '■'; //代表墻
 char blank = '○'; //代表空地
 char[][] maze; //迷宮
 boolean[][] visit; //用來標(biāo)記某一格是否被訪問過
 Node start = new Node(0,0); //開始節(jié)點
 Node exit = new Node(len - 1, wid - 1); //出口,其實現(xiàn)在也沒什么用,因為沒有交互只是生成了一個迷宮而已
 Node cur; //當(dāng)前格
 Node next; //下一格
 Stack<Node> path = new Stack<Node>(); //表示路徑的棧
 int[][] adj = {
  {0,2},{0,-2},{2,0},{-2,0}
 }; //用來計算鄰接格
 /**
 * 迷宮的格子類
 * @author Yan
 */
 class Node
 {
 int x,y;
 public Node(){}
 public Node(int x, int y)
 {
  this.x = x;
  this.y = y;
 }
 public String toString() {
  return "Node [x=" + x + ", y=" + y + "]";
 }
 }
 /**
 * 初始化,初始化迷宮參數(shù)
 */
 void init()
 {
 maze = new char[len][wid];
 visit = new boolean[len][wid];
 for(int i = 0; i < len; i++)
 {
  for(int j = 0; j < wid; j++)
  {
  maze[i][j] = wall;
  visit[i][j] = false;
  }
 }
 visit[start.x][start.y] = true;
 maze[start.x][start.y] = blank;
 cur = start; //將當(dāng)前格標(biāo)記為開始格
 }
 /**
 * 打印結(jié)果
 */
 void printMaze()
 {
 for(int i = 0; i < len; i++)
 {
  for(int j = 0; j < wid; j++)
  {
  System.out.print(maze[i][j] + " ");
//  if(maze[i][j] == '○')
//  {
//   System.err.print(maze[i][j] + " ");
//  }
//  else
//  {
//   System.out.print(maze[i][j] + " ");
//  }
//  try {
//   Thread.sleep(100);
//  } catch (InterruptedException e) {
//   e.printStackTrace();
//  }
  }
  System.out.println();
 }
 System.out.println("==========================================");
 }
 /**
 * 開始制作迷宮
 */
 void makeMaze()
 {
 path.push(cur); //將當(dāng)前格壓入棧
 while(!path.empty())
 {
  Node[] adjs = notVisitedAdj(cur);//尋找未被訪問的鄰接格
  if(adjs.length == 0)
  {
  cur = path.pop();//如果該格子沒有可訪問的鄰接格,則跳回上一個格子
  continue;
  }
  next = adjs[new Random().nextInt(adjs.length)]; //隨機(jī)選取一個鄰接格
  int x = next.x;
  int y = next.y;
  //如果該節(jié)點被訪問過,則回到上一步繼續(xù)尋找
  if(visit[x][y])
  {
  cur = path.pop();
  }
  else//否則將當(dāng)前格壓入棧,標(biāo)記當(dāng)前格為已訪問,并且在迷宮地圖上移除障礙物
  {
  path.push(next);
  visit[x][y] = true;
  maze[x][y] = blank;
  maze[(cur.x + x) / 2][(cur.y + y) / 2] = blank; //移除當(dāng)前格與下一個之間的墻壁
  cur = next;//當(dāng)前格等于下一格
  }
 }
 }
 /**
 * 判斷節(jié)點是否都被訪問
 * @param ns
 * @return
 */
 boolean allVisited(Node[] ns)
 {
 for(Node n : ns)
 {
  if(!visit[n.x][n.y])
  return false;
 }
 return true;
 }
 /**
 * 尋找可訪問的鄰接格,這里可以優(yōu)化,不用list
 * @param node
 * @return
 */
 Node[] notVisitedAdj(Node node)
 {
 List<Node> list = new ArrayList<Node>();
 for(int i = 0; i < adj.length; i++)
 {
  int x = node.x + adj[i][0];
  int y = node.y + adj[i][1];
  if( x >= 0 && x < len && y >= 0 && y < wid)
  {
  if(!visit[x][y])
   list.add(new Node(x,y));
  }
 }
 Node[] a = new Node[list.size()];
 for(int i = 0; i < list.size(); i++)
 {
  a[i] = list.get(i);
 }
 return a;
 }
 /**
 * 入口方法
 * @param args
 */
 public static void main(String[] args) {
 Maze m = new Maze();
 m.init();
 m.makeMaze();
 m.printMaze();
 }
}

總結(jié)

以上就是這篇文章的全部內(nèi)容了,希望本文的內(nèi)容對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,謝謝大家對億速云的支持。如果你想了解更多相關(guān)內(nèi)容請查看下面相關(guān)鏈接

向AI問一下細(xì)節(jié)

免責(zé)聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉(zhuǎn)載和分享為主,文章觀點不代表本網(wǎng)站立場,如果涉及侵權(quán)請聯(lián)系站長郵箱:is@yisu.com進(jìn)行舉報,并提供相關(guān)證據(jù),一經(jīng)查實,將立刻刪除涉嫌侵權(quán)內(nèi)容。

AI