‡ CODING TEST STUDY ‡/º 프로그래머스
                
              [프로그래머스 | Java Lv.2] 모음사전
                Trudy | 송연
                 2024. 5. 18. 15:03
              
                          
            문제
https://school.programmers.co.kr/learn/courses/30/lessons/84512
프로그래머스
코드 중심의 개발자 채용. 스택 기반의 포지션 매칭. 프로그래머스의 개발자 맞춤형 프로필을 등록하고, 나와 기술 궁합이 잘 맞는 기업들을 매칭 받으세요.
programmers.co.kr
접근
이번 문제는 어떤 순서로 풀어야할 지 쉽게 알 수 있었던 문제였다.
1. 길이가 5 이하인 사전을 만든다.
2. 주어진 word를 검색해서 index + 1을 반환한다.
사전 만들기
사전 만드는 것은 dfs를 사용해서 풀면 됐던 문제!
    public void dfs(String[] s, String result, int length){
    	//길이가 맞으면, list에 추가
        if(result.length() == length) list.add(result);
        else{
            for (int i = 0; i < s.length; i++) {
                dfs(s, result + s[i], length);
            }
        }
    }
    public int solution(String word) {
        String[] s = {"A", "E", "I", "O", "U"};
		
        //길이가 1부터 5까지이므로 5번 dfs를 직접 호출해줌
        for (int i = 1; i <= 5; i++) {
            dfs(s, "", i);
        }
        
        Collections.sort(list);
    }
}
최종 코드
package week3.baek.exhaustivesearch;
import java.util.ArrayList;
import java.util.Collections;
public class Ex7 {
    ArrayList<String> list = new ArrayList<>();
    public void dfs(String[] s, String result, int length){
        if(result.length() == length) list.add(result);
        else{
            for (int i = 0; i < s.length; i++) {
                dfs(s, result + s[i], length);
            }
        }
    }
    public int solution(String word) {
        int answer = 0;
        String[] s = {"A", "E", "I", "O", "U"};
        for (int i = 1; i <= 5; i++) {
            dfs(s, "", i);
        }
//        System.out.println(list);
        Collections.sort(list);
//        System.out.println(list);
        return list.indexOf(word) + 1;
    }
}
class Ex7Main{
    public static void main(String[] args) {
        Ex7 ex7 = new Ex7();
        String word = "AAAAE";
        System.out.println(ex7.solution(word));
    }
}