🤍 전 강의 25% 할인 중 🤍

2024년 상반기를 돌아보고 하반기에도 함께 성장해요!
인프런이 준비한 25% 할인 받으러 가기 >>

  • 카테고리

    질문 & 답변
  • 세부 분야

    알고리즘 · 자료구조

  • 해결 여부

    미해결

코드 질문

21.01.23 00:36 작성 조회수 102

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

안녕하세요^^

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

채널톡 아이콘