티스토리 뷰

반응형

https://programmers.co.kr/learn/courses/30/lessons/43163

 

코딩테스트 연습 - 단어 변환

두 개의 단어 begin, target과 단어의 집합 words가 있습니다. 아래와 같은 규칙을 이용하여 begin에서 target으로 변환하는 가장 짧은 변환 과정을 찾으려고 합니다. 1. 한 번에 한 개의 알파벳만 바꿀 수

programmers.co.kr


⊙ 문제

⊙ 제한사항

⊙ 입출력 예

⊙ 입출력 예 설명


 

⊙ 문제 접근 과정

 

방문 여부와 단어 차이로 bfs를 돌려주었다.

 

먼저 queue에 시작 단어를 넣는다. 그리고 그 단어가 words안에 없다면 바로 0을 리턴해준다.

그렇지만 단어가 words 안에 있다면 words를 탐색하여 단어가 하나만 다르고 방문한 적 없는 단어를 queue에 append 해준다. append시 ans 값을 count up을 같이 해준다.

 

그렇게 반복하여서 마지막에 ans를 리턴해주면 결과가 성공적으로 나온다.

 


 

⊙ 문제 풀이

 

from collections import deque
def solution(begin, target, words):
    ans=0

    if target not in words:
        return 0
    
    q = deque()
    q.append(begin)
    visited = [0 for _ in words]

    while q:
        x = q.popleft()
        if x == target:
            return ans

        for i in range(len(words)):
            count = 0
            for j in range(len(begin)):
                if x[j] != words[i][j]:
                    count+=1
            if count==1 and not visited[i]:
                q.append(words[i])
                visited[i]=1
                ans+=1
    return ans

⊙ 마무리

 

 

좋은 문제라고 생각한다. 나중에 한번 더 풀어야지.

 

 

좋아요는 로그인하지 않아도 누를 수 있습니다!

728x90
반응형
댓글
공지사항
최근에 올라온 글
최근에 달린 댓글
Total
Today
Yesterday
링크
«   2025/01   »
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
글 보관함