91超碰碰碰碰久久久久久综合_超碰av人澡人澡人澡人澡人掠_国产黄大片在线观看画质优化_txt小说免费全本

溫馨提示×

java尋路算法怎么實現

小億
99
2023-09-21 23:23:08
欄目: 編程語言

Java中的尋路算法可以使用圖的搜索算法來實現。以下是一個簡單的示例,使用BFS(廣度優先搜索)算法來尋找路徑。

import java.util.*;
public class PathFinding {
// 定義圖的大小
private static final int ROW = 5;
private static final int COL = 5;
// 定義圖的節點
private static class Node {
int x;
int y;
Node parent;
public Node(int x, int y, Node parent) {
this.x = x;
this.y = y;
this.parent = parent;
}
}
// 定義可移動的方向
private static final int[][] DIRECTIONS = {{-1, 0}, {1, 0}, {0, -1}, {0, 1}};
// 判斷點是否在圖內
private static boolean isValid(int x, int y) {
return x >= 0 && x < ROW && y >= 0 && y < COL;
}
// 判斷點是否為障礙物(1表示障礙物)
private static boolean isObstacle(int[][] grid, int x, int y) {
return grid[x][y] == 1;
}
// 尋找路徑
public static List<Node> findPath(int[][] grid, Node start, Node end) {
List<Node> path = new ArrayList<>();
// 使用BFS算法
Queue<Node> queue = new LinkedList<>();
queue.offer(start);
boolean[][] visited = new boolean[ROW][COL];
visited[start.x][start.y] = true;
while (!queue.isEmpty()) {
Node curr = queue.poll();
if (curr.x == end.x && curr.y == end.y) {
// 找到目標節點,構建路徑
while (curr != null) {
path.add(0, curr);
curr = curr.parent;
}
break;
}
// 遍歷可移動的方向
for (int[] direction : DIRECTIONS) {
int newX = curr.x + direction[0];
int newY = curr.y + direction[1];
if (isValid(newX, newY) && !isObstacle(grid, newX, newY) && !visited[newX][newY]) {
Node next = new Node(newX, newY, curr);
queue.offer(next);
visited[newX][newY] = true;
}
}
}
return path;
}
public static void main(String[] args) {
// 定義一個示例地圖
int[][] grid = {
{0, 0, 0, 0, 0},
{1, 1, 1, 1, 0},
{0, 0, 0, 0, 0},
{0, 1, 1, 1, 1},
{0, 0, 0, 0, 0}
};
Node start = new Node(0, 0, null);
Node end = new Node(4, 4, null);
List<Node> path = findPath(grid, start, end);
if (path.isEmpty()) {
System.out.println("No path found.");
} else {
System.out.println("Path found:");
for (Node node : path) {
System.out.println("(" + node.x + ", " + node.y + ")");
}
}
}
}

這個示例中,使用一個二維數組來表示地圖,0表示可通行的區域,1表示障礙物。findPath方法使用BFS算法來尋找路徑,返回一個包含節點的列表。最后在main方法中進行測試,輸出找到的路徑。

0
怀来县| 永嘉县| 克什克腾旗| 吉木萨尔县| 普格县| 视频| 永和县| 佳木斯市| 新乡县| 南江县| 宿州市| 甘洛县| 剑川县| 富裕县| 青浦区| 上思县| 桑日县| 澄江县| 独山县| 元江| 紫云| 包头市| 朝阳县| 方山县| 新巴尔虎左旗| 平潭县| 成武县| 大石桥市| 新营市| 永登县| 湛江市| 莆田市| 伽师县| 大荔县| 青州市| 盐池县| 沾化县| 华坪县| 乌审旗| 分宜县| 封丘县|