[プログラマープログラマー]単語変換(DFSプール)-Java JAVA


手前のBFSプール
BFSプール
問題の説明
質問リンク

考えを整理する.
// dfs 함수 내에서 탐색할 단어와 target단어가 같다면
	// 최소변환 과정을 업데이트 시켜줘야함 (BFS에서는 이 과정이 필요가 없음)
    // 리턴한다.
// words 배열을 탐색한다.
	// 해당 idx를 방문하지 않았다면
    	//탐색할 단어와 target단어를 비교하면서 '한개의 알파벳만 다른지' 확인한다.
		//한개의 알파벳만 다르다면
        	//해당 idx를 방문표시한다.
            //해당 단어를 가지고 dfs함수를 부른다.
            //방문표시를 해제한다. (재귀함수에서 리턴이 되었다는 것은, 이전단계로 돌아왔다는 것이며, 이는 해당 idx를 방문하지 않음을 의미하기 때문에 방문표시를 해제한다.)
           
筋道
「幅優先検索」(BFS)を使用して解凍する場合、最初に見つかった変換プロセスは最短の変換プロセスと言えるため、最短の変換プロセスを更新するのは単独では経験しません.
しかし,DFS(深度優先ナビゲーション)は最短の変換過程とは言えないため,最短の変換過程を更新する必要がある.(それができなかった場合、すべてのテストケースに合格しませんでした.)
DFSとBFSの最大の違いだと思います.
完了
class Solution {
    static boolean[] visited;
    static int answer = 0;
    public int solution(String begin, String target, String[] words) {
        visited = new boolean[words.length];
        dfs(begin, target, words, 0);
        return answer;
    }
    
    static void dfs(String begin, String target, String[] words, int cnt) {
        if(begin.equals(target)) {
            if(answer >= cnt || answer == 0) {
                answer = cnt;
            } 
            //answer는 target을 찾는데 까지 걸린 단계를 의미한다.
            //answer이 cnt보다 크거나 같은 경우, 즉 기존에 걸린 단계수 가 이번에 찾은 단계수보다 크거나 같다면, answer는 업데이트 된다. (answer가 0일 때도 업데이트 해준다.)
            return ;
        }
        
        for(int i=0; i<words.length; i++) {
            if(visited[i]) continue;
            
            int count = 0;
            for(int j=0; j<begin.length(); j++) {
                if(begin.charAt(j) == words[i].charAt(j)){
                    count++;
                }
            }
            
            if(count == begin.length()-1) {
                visited[i] = true;
                dfs(words[i], target, words, cnt+1);
                visited[i] = false;
            }
        }
    }
}


私が考えているこの問題について、BFSとDFSのプロセスは以下の通りです.
(DFSよりバックグラウンドトラッキングと見なすべきだと思います.)