Algorithm/Level 0

[Level 0] 문자열 등장 횟수

쩨리쩨리 2023. 7. 27. 08:17
반응형

문제 

숫자로 이루어진 문자열 s가 있습니다. 
이 문자열에서 가장 많이 등장하는 0 ~ 9 사이의 숫자를 출력하는 프로그램을 구현하세요.
단, 가장 많이 등장하는 수가 여러 개라면, 그 중 가장 작은 수를 반환하세요.

 

입력 형식

  • s 는 숫자로 이루어진 문자열 

 

출력 형식

  • 가장 많이 등장하는 수를 정수로 반환 

 

제약 사항 

  • 0 < s.length <= 100

 

입출력 예시 

  • 예시1
  • 입력 : s = "174771177"
  • 출력 : 7
  • 설명 : 7이 가장 많이 등장하였으므로 답은 7이다.

 

  • 예시2
  • 입력 : s = "552342502"
  • 출력 : 2
  • 설명 : 2와 5가 가장 많이 등장하지만, 2가 더 작으므로 2를 반환 

 


내 풀이

function solution(s) {
    const setArr = [...new Set(s)].sort((a,b) => a-b);
    let max = 0;
    let result = 0;
    setArr.forEach((v) => {
        let count = [...s].reduce((a,c) => c === v ? a += 1 : a, 0);
        if(max < count) {max = count; result = +v}
        else if (max === count) {
            result = Math.min(result, +v);
        }
    });

    return result;
}

 

  • 시간 복잡도 : O(n^2)
  • 설명 : 해당 코드는 문자열 s를 중복을 제거한 후 정렬하여 setArr 배열에 저장한다. 그리고 setArr 배열을 순회하면서 각 문자(v)가 s에 몇 번 등장하는지 세는데, 이를 위해 또 다시 s를 배열로 만들어 reduce 메서드를 사용한다. 이렇게 되면 각 문자마다 다시 전체 문자열을 검사하므로 시간 복잡도가 O(n)인 reduce 메서드를 setArr의 길이만큼 호출하게 된다. 이는 효율적이지 않은 방법이며, 특히 문자열이 매우 긴 경우에는 성능이 더욱 저하될 수 있다.

 


해결 방법

function solution(s) {
  const charCounts = new Map();

  for (const char of s) {
    if (charCounts.has(char)) {
      charCounts.set(char, charCounts.get(char) + 1);
    } else {
      charCounts.set(char, 1);
    }
  }

  let maxCount = 0;
  let resultChar;

  charCounts.forEach((count, char) => {
    if (count > maxCount) {
      maxCount = count;
      resultChar = char;
    } else if (count === maxCount && char < resultChar) {
      resultChar = char;
    }
  });

  return resultChar;
}

 

  • 시간 복잡도 : O(n)
  • 설명 : 해결 방법으로는 문자열을 한 번만 순회하면서 각 문자의 등장 횟수를 세는 방법이 있다. 이렇게 하면 중복 계산을 피할 수 있으며, 시간 복잡도를 O(n)으로 개선할 수 있다. ⇒ 문자의 등장 횟수를 세는 방법으로 map을 사용하자.
반응형