강의

멘토링

커뮤니티

인프런 커뮤니티 질문&답변

조영규님의 프로필 이미지
조영규

작성한 질문수

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

7. 송아지 찾기(BFS: Breadth First Search)

코드 질문

작성

·

168

0

안녕하세요 

수업시간에 올려주신 코드를 보면 deque에서 pop할 때 m값이 나올 때 break를 걸어주었습니다. 그런데 for문에서 next값에서 m이 나올 때 바로 break를 걸어주는 것이 이후에 deque에서 m이 나올때까지 더 찾지 않으므로 효율적인것 같아서 아래와 같이 짜보았는데 효율성 측면에서 별 차이가 없는 건가요?

start,end=map(int,input().split())

max=10000

ch=[0]*(max+1)

dis=[0]*(max+1)

ch[start]=1

dis[start]=0

dq=deque()

dq.append(start)

bp=False

while dq:

    now=dq.popleft()

    for next in(now-1,now+1,now+5):

        if 0<next<=max:

            if ch[next]==0:

                dq.append(next)

                ch[next]=1

                dis[next]=dis[now]+1

                if next==end:

                    bp=True

                    break

    if bp:

        break

print(dis[end])

답변 1

0

김태원님의 프로필 이미지
김태원
지식공유자

안녕하세요^^

네 그렇게 하면 효율이 더 좋은게 확실합니다. 

조영규님의 프로필 이미지
조영규

작성한 질문수

질문하기