Skip to content

Data structure HW. Implement Dijkstra's algorithm by min heap data structure using C++ language

Notifications You must be signed in to change notification settings

zhamba1130/dijkstras-algorithm-cpp

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 

History

9 Commits
 
 
 
 
 
 

Repository files navigation

dijkstras-algorithm-cpp

Implement Dijkstra's algorithm by min heap data structure

1 Problem Description

The poison maze is a square room full of poisonous liquid, every step you go, you get hurt. The maze can be described as an N×N grid. For better understanding of the input data, we define +x direction is RIGHT and +y direction is DOWN. Depending on the density of poison, walking on different grid points results in different amounts of damage. You start at point (1,1) (top left), and there is an exit at the diagonal corner (N, N) (bottom right). The damage at each grid point is given. You need to escape from this maze with as little damage as possible. In this problem, the main target is to implement a search algorithm to find a path from (1,1) to (N, N) with the smallest total damage.

2 Input

There will be 10 test data in 3 different sizes. The first line of each input file contains an integer N, the maze will be a N×N Grid. Then there will be N lines following, every lines contain N integers. For the i-th line, the j-th number denote the damage of the point (i, j) when you walk on it

3 Output

For each test, please output a file with 2 lines: In the first line, please output 2 integer C, S. C is the smallest possible damage (length of theshortest path), and S is the number of steps of this path. In the second line, please output a string of S−1 characters, consist of 4 characters: { ’U’, ’D’, ’L’, ’R’} (denoting “up”, “down”, “left”, “right”) describing every step from (1,1) to (N, N).

4 Samples

image

About

Data structure HW. Implement Dijkstra's algorithm by min heap data structure using C++ language

Topics

Resources

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published

Languages