선생님! (알파코드 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코드라 선생님이 보시기엔 어떤지가 궁금합니다..!! ㅎㅎ
답변 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





