목차
#1 문자열 묶기
문제 설명
문자열 배열 strArr이 주어집니다. strArr의 원소들을 길이가 같은 문자열들끼리 그룹으로 묶었을 때 가장 개수가 많은 그룹의 크기를 return 하는 solution 함수를 완성해 주세요.
제한사항
- 1 ≤ strArr의 길이 ≤ 100,000
- 1 ≤ strArr의 원소의 길이 ≤ 30
- strArr의 원소들은 알파벳 소문자로 이루어진 문자열입니다.
입출력 예
strArr | result |
["a","bc","d","efg","hi"] | 2 |
입출력 예 설명
입출력 예 #1
- 각 문자열들을 길이에 맞게 그룹으로 묶으면 다음과 같습니다.
문자열 길이 | 문자열 목록 | 개수 |
1 | ["a","d"] | 2 |
2 | ["bc","hi"] | 2 |
3 | ["efg"] | 1 |
- 개수의 최댓값은 2이므로 2를 return 합니다.
#2 알고리즘 및 코드
import java.util.HashMap;
import java.util.Map;
class Solution {
public int solution(String[] strArr) {
// 문자열 길이를 기준으로 그룹을 만들기 위한 Map
Map<Integer, Integer> groupCountMap = new HashMap<>();
// 문자열 배열을 순회하면서 각 길이의 그룹 개수를 세기
for (String str : strArr) {
int length = str.length();
groupCountMap.put(length, groupCountMap.getOrDefault(length, 0) + 1);
}
// 가장 개수가 많은 그룹의 크기 찾기
int maxGroupSize = 0;
for (int groupSize : groupCountMap.values()) {
maxGroupSize = Math.max(maxGroupSize, groupSize);
}
return maxGroupSize;
}
}
728x90
'JAVA > 프로그래머스 코딩 기초 트레이닝' 카테고리의 다른 글
[프로그래머스 LV.0] 뒤에서 5등까지 (0) | 2024.02.16 |
---|---|
[프로그래머스 LV.0] 배열의 길이에 따라 다른 연산하기 (0) | 2024.02.16 |
[프로그래머스 LV.0] 배열 비교하기 (0) | 2024.02.16 |
[프로그래머스 LV.0] 배열의 길이를 2의 거듭제곱으로 만들기 (0) | 2024.02.16 |
[프로그래머스 LV.0] 무작위로 k개의 수 뽑기 (0) | 2024.02.16 |