230307 가사 검색

Jongleee·2023년 3월 7일
0

TIL

목록 보기
199/786
public static List<Integer> solution(String[] words, String[] queries) {
    Map<Integer, List<String>> frontMap = new HashMap<>();
    Map<Integer, List<String>> backMap = new HashMap<>();

    for (String word : words) {
        int len = word.length();
        frontMap.computeIfAbsent(len, ArrayList::new).add(word);
        backMap.computeIfAbsent(len, ArrayList::new).add(reverse(word));
    }

    frontMap.values().forEach(Collections::sort);
    backMap.values().forEach(Collections::sort);

    List<Integer> answer = new ArrayList<>();
    for (String query : queries) {
        List<String> list;
        if (query.charAt(0) == '?') {
            list = backMap.get(query.length());
            query = reverse(query);
        } else {
            list = frontMap.get(query.length());
        }

        if (list == null) {
            answer.add(0);
        } else {
            String upperBoundQuery = query.replace('?', Character.MAX_VALUE);
            String lowerBoundQuery = query.replace("?", "");
            int upperBound = findBound(list, upperBoundQuery);
            int lowerBound = findBound(list, lowerBoundQuery);

            answer.add(upperBound - lowerBound);
        }
    }

    return answer;
}

private static int findBound(List<String> list, String str) {
    int start = 0;
    int end = list.size();

    while (start < end) {
        int mid = (start + end) / 2;

        if (list.get(mid).compareTo(str) >= 0) {
            end = mid;
        } else {
            start = mid + 1;
        }
    }

    return start;
}

private static String reverse(String s) {
    return new StringBuilder(s).reverse().toString();
}

이분탐색을 이용해 쿼리의 최대값과 최솟값을 찾는 방식으로 해당하는 갯수를 구함

0개의 댓글