inflearn logo
강의

강의

N
챌린지

챌린지

멘토링

멘토링

N
클립

클립

로드맵

로드맵

지식공유

파이썬 알고리즘 문제풀이 입문(코딩테스트 대비)

6. 알파코드(DFS)

선생님! (알파코드 DFS)

205

핑구몬

작성한 질문수 3

0

import sys
input = sys.stdin.readline

# 아스키 : chr(x)
# 0 입력되면 입력 종료

def DFS(L):
    global cnt, res
    if L == len(num):
        if len(res) > len(num):
            res = res[2:]   # pop, slicing 둘 다 O(N). pop(0)을 2번 하면, 2N이니까 슬라이싱 사용. pop(0)을 O(1)로 하려면 deque사용하면 됨
        print("".join(res))
        # print(res)
        cnt += 1
        return
    a = int(num[L])
    b = int("".join(num[L:L+2]))
    if a == 0:
        return
    if 0 < a < 10:
        res.append(chr(a+64))
        # res.append(a)
        DFS(L+1)
        res.pop()
    if 9 < b < 27:
        res.append(chr(b+64))
        # res.append(b)
        DFS(L+2)
        res.pop()
    
if __name__ == "__main__":
    num = list(str(input()).rstrip())
    res = []
    cnt = 0
    DFS(0)
    print(cnt)
- 학습 관련 질문을 남겨주세요. 상세히 작성하면 더 좋아요!
- 먼저 유사한 질문이 있었는지 검색해보세요.
- 서로 예의를 지키며 존중하는 문화를 만들어가요.
- 잠깐! 인프런 서비스 운영 관련 문의는 1:1 문의하기를 이용해주세요.
 
 
 
강의에 나온 방법 외에
숫자를 1글자, 2글자로 나눠서 트리를 만드는 방법으로 코드를 구현해봤는데 어떤가요...?! 괜찮은가요??!
for문을 이용하지 않고 거의다 조건문으로 굴러가는 코드인데, 시간복잡도 등 차이가 많이 있을까요??
처음으로 정답코드 안보고 구현해본 DFS코드라 선생님이 보시기엔 어떤지가 궁금합니다..!! ㅎㅎ

코테 준비 같이 해요! python

답변 1

1

김태원

안녕하세요^^

처음 스스로 한 코드라고 보기 힘들 정도로 좋은 코드입니다. 화이팅하세요^^

기존에 윈도우 10으로 잘 써왔는데 윈도우 11로 바꾸고 나서 채점이 안됩니다.

1

104

2

스택에서 ')'을 만나는 경우

0

112

3

문제가 어디있나요?

0

87

2

변수 or 함수명

0

81

1

침몰하는 타이타닉 문제 질문입니다

0

72

1

AA.py 책점 에러

0

65

1

오늘 구매했는데 파이썬 자료구조 궁금한거 있으면 답변이 잘 될까요.

0

117

2

5.동전분배하기 문제 밑에코드도 정답이될까요?

0

118

1

아나그램 비교 코드

0

126

2

AA.PY파일 복사 후 채점 진행할때 오류 발생합니다.

0

164

2

문제 링크가있나여?

0

155

2

채점기 Time Limit Exceeded 오류 문의

1

183

2

동적계획법은 사용하는 문제

0

135

2

제 코드 좀 봐주세요

0

155

1

예외가 존재할 가능성?

0

100

1

3번이 안풀립니다

0

98

0

5번 틀림

0

125

0

오류원인?

0

106

0

리스트 선언

0

116

1

침몰하는 타이타닉(그리디) 문제 질문

0

115

1

알고리즘

0

74

1

코딩테스트

0

98

1

DFS 순서 질문드립니다.

0

139

2

left, right를 사용한 풀이법에 대한 질문입니다

0

102

1