Post

Programmers_DFS/BFS 여행경로(python)

Programmers_DFS/BFS 여행경로(python)

프로그래머스 -여행경로 문제 입니다.

1. 문제

https://programmers.co.kr/learn/courses/30/lessons/43164#


2. 분류 및 난이도

Programmers 문제입니다.
깊이/너비 우선 탐색 DFS/BFS 문제입니다.

Level 3난이도의 문제입니다.


3. 생각한 것들(문제 접근 방법)

  • 백트래킹 방법을 사용하지 않으면 시간초과가 뜹니다.
  • python에서 재귀 동작방식에 대한 이해가 부족하여 결과값들을 다 넣고 앞부분만 잘랐습니다. 개선이 필요합니다.

4. 접근 방법을 적용한 코드

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
from collections import deque
def DFS(templi,dic,start,finish,v,answer):
    #결과값은 항상 주어진 tickets 리스트의 크기 +1입니다.
    if len(templi) == finish : 
        # 결과값을 다 넣어버립니다.
        for i in range(len(templi)):
            answer.append(templi[i])
        return templi
    #dictionary에 값이 있을 때
    if start in dic : 
        for i in range(len(dic[start])) :
            # 방문 처리가 되지 않은 것들을 돕니다.
            if v[start][i]==0 : 
                #templi에 추가
                templi.append(dic[start][i])
                #방문처리
                v[start][i] = 1
                # 재귀
                DFS(templi,dic,dic[start][i],finish,v,answer)
                #맨 뒤의 값을 제거 및 방문처리 제거합니다.
                templi.pop()
                v[start][i] = 0
        return templi

    
def solution(tickets):
    answer = []
    dic = {}
    v = {}
    finish = len(tickets)+1
    #dic에 dic[출발지] = 도착지 값들을 deque형태로 저장합니다. 방문처리를 위한 v도 마찬가지로 저장합니다. 0은 방문하지 않은 것 1은 방문한 것입니다.
    for i in range(len(tickets)):
        start = tickets[i][0]
        end = tickets[i][1]
        if start not in dic:
            dic[start] = deque()
            v[start] = deque()
            dic[start].append(end)
            v[start].append(0)
        else : 
            dic[start].append(end)
            v[start].append(0)
    #정렬
    for i in dic : 
        dic[i] = sorted(dic[i])
    DFS(["ICN"],dic,"ICN",finish,v,answer)
    # 결과값들을 다 넣었으므로 앞부분을 자릅니다. 이미 정렬을 했기에 앞부분이 정답일 수 밖에 없습니다.
    return answer[:finish]

5. 결과

필요시. c++ 짜드리겠습니다. 설명이 필요시 댓글달아주세요.

This post is licensed under CC BY 4.0 by the author.