TheAlgorithms-Ruby/searches/depth_first_search.rb

54 lines
1,005 B
Ruby
Raw Normal View History

2020-10-04 13:06:47 +07:00
# @param [Integer] start
# @param [Integer] target
# @param [Array] adjacency_list
# @return [Array] routes
def dfs(start, target, adjacency_list)
is_visited = Hash.new(false)
parent = {}
stack = [start]
loop do
break if stack.empty?
2021-02-06 23:05:54 -08:00
2020-10-04 13:06:47 +07:00
current_node = stack.pop
is_visited[current_node] = true
return get_path(parent, target) if current_node == target
adjacency_list[current_node].each do |neighbor|
next if is_visited[neighbor]
2021-02-06 23:05:54 -08:00
2020-10-04 13:06:47 +07:00
stack << neighbor
is_visited[neighbor] = true
parent[neighbor] = current_node
end
end
[]
end
# @param [Hash] parent
# @param [Integer] dest
# @return [Array] path
def get_path(parent, dest)
iterator = dest
path = [dest]
while parent.has_key?(iterator)
path << parent[iterator]
iterator = parent[iterator]
end
path.reverse
end
def main
adjacency_list = [
2021-02-06 23:05:54 -08:00
[1, 2], # 0
[0, 3], # 1
[0, 3], # 2
[1, 2, 4], # 3
[3, 5], # 4
[4] # 5
2020-10-04 13:06:47 +07:00
]
p dfs(0, 5, adjacency_list)
end
main