240202 가사 검색

Jongleee·2024년 2월 2일
0

TIL

목록 보기
485/786
public 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> wordList;

		if (query.charAt(0) == '?') {
			wordList = backMap.get(query.length());
			query = reverse(query);
		} else {
			wordList = frontMap.get(query.length());
		}

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

			answer.add(upperBound - lowerBound);
		}
	}

	return answer;
}

private int findBound(List<String> wordList, String query) {
	int start = 0;
	int end = wordList.size();

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

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

	return start;
}

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

출처:https://school.programmers.co.kr/learn/courses/30/lessons/60060

0개의 댓글