극동대학교\AI컴퓨터공학과\JAVA/프로그래머스 코딩 기초 트레이닝

[프로그래머스 LV.0] 문자열 묶기

sundori 2024. 2. 16. 15:22

목차

#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;
    }
}