This is the sixth day of my participation in the August More text Challenge. For details, see: August More Text Challenge

Pathfinding in the program to achieve a certain pathfinding algorithm to solve, how to find a path in the shortest time the shortest route, this is the pathfinding algorithm to consider the first problem.

How pathfinding

The way you see walking:

The way developers actually see it:

For a map, developers need to pass a certain program converts it to a data object, common is above the cut the map into a grid, and of course the classified methods of map doesn’t have to use this way, the grid using polygon can also, depending on your game, under normal circumstances, the same area of the map using fewer vertices, pathfinding algorithm will be faster. A common data structure used in pathfinding is a graph, which we’ll take a look at below.

Figure Graph

Before talking about pathfinding algorithm, let’s first understand a kind of data structure — Graph. Data structure is the basis of our algorithm operation. A good data structure will not only facilitate our understanding of the algorithm, but also improve the efficiency of the algorithm. In a sense, the grid is also the evolution of the graph, but the graph has changed. Understanding the concept of the graph can help us better understand the pathfinding algorithm.

Basic definition of graph:

The formal expression of the graph is G=(V,E), where V is the set of vertices, and E and V are a binary relation, which can be understood as an edge, for example, if there is an edge that ends from vertex U to vertex V, then E can represent that edge in terms of (U, V). The specific differentiation between directed and undirected graphs is also whether the edges have direction. For the convenience of understanding, all the data demonstration in this paper is based on grid map. The following is A comb of several relationships. With A as the vertex and BCDE as the sub-vertices, we can see that each grid is also A vertex.

Search algorithm

Searching a graph means accessing its vertices in some particular order. For multi-graph algorithms, both breadth-first and depth-first search algorithms are important because they provide a systematic way to access graph data structures. We’ll focus on breadth-first search algorithms.

  1. Depth-first search

The depth-first algorithm has little to do with the minimum path, so we’ll just introduce it briefly.

Depth first search algorithm (DFS) is an algorithm used to traverse or search a tree or graph. Traverse the nodes of the tree along the depth of the tree, searching for branches of the tree as deep as possible. When all the edges of node V have been explored, the search will go back to the starting node of the edge where node V was found. This process continues until all nodes reachable from the source node have been discovered.

  1. Breadth-first search

Breadth first search algorithm (BFS), also known as width first search, is a graph search algorithm. It is suitable for the first model to explore the shortest path, and we will follow this idea.

BFS is a blind search method designed to systematically expand and examine all nodes in a graph for results. In other words, it does not consider the possible address of the result and thoroughly searches the entire graph until it finds the result.

  • First put the root node into the queue.
  • The first node is pulled from the queue and checked to see if it is the target.
  • If the target is found, the search ends and results are returned.
  • Otherwise, all of its direct children (neighbors) that have not been tested are added to the queue.
  • If the queue is empty, the entire graph is checked — that is, there are no targets in the graph to search for. End search and return “no target found”.

Grid:

Let’s look at the code (JS) :

From the above, we can find that the width search is to start from the starting vertex, access the child nodes (in the grid, access the surrounding nodes), and then continue to loop this process until the target is found. This algorithm is more in line with conventional logic, all the vertices are enumerated once. There are obvious downsides to this approach.

1. The time complexity is :T(n) = O(n^2)

2. There is no weight between each vertex, no priority can be defined, no optimal route can be found. For example, we need to walk around water, which cannot be involved in the width algorithm.

How to solve this problem? Let’s look at Dijkstra’s algorithm.

For Dijkstra algorithm, see -> Path Algorithm (2)