-
[프로그래머스] 문자열 나누기알고리즘 2023. 6. 25. 21:57
문제
문자열 s가 입력되었을 때 다음 규칙을 따라서 이 문자열을 여러 문자열로 분해하려고 합니다.
먼저 첫 글자를 읽습니다. 이 글자를 x라고 합시다.
이제 이 문자열을 왼쪽에서 오른쪽으로 읽어나가면서, x와 x가 아닌 다른 글자들이 나온 횟수를 각각 셉니다.처음으로 두 횟수가 같아지는 순간 멈추고, 지금까지 읽은 문자열을 분리합니다.
s에서 분리한 문자열을 빼고 남은 부분에 대해서 이 과정을 반복합니다. 남은 부분이 없다면 종료합니다.
만약 두 횟수가 다른 상태에서 더 이상 읽을 글자가 없다면, 역시 지금까지 읽은 문자열을 분리하고, 종료합니다.
문자열 s가 매개변수로 주어질 때, 위 과정과 같이 문자열들로 분해하고, 분해한 문자열의 개수를 return 하는 함수 solution을 완성하세요.풀이
제시한 문자열 s를 가지고 주어진 조건들을 체크하면서 진행하는 문제이다.
s를 처음부터 끝 까지 순회하여 O(n)을 만족하도록 하였다.
x의 수를 세는 xCount와 그 이외의 문자를 세는 nonXCount변수를 두어서 비교를 하도록 하였다.
후에 두 변수의 값이 다르면 문자를 모두 분리하지 못하고 끝났다는 것이므로 값이 다르면 분리를 한번 더 하도록 한다.class Solution { public int solution(String s) { int answer = 0; int xCount = 0; int nonXCount = 0; String x = ""; for(int i = 0; i < s.length(); i++) { String str = s.substring(i, i + 1); if (xCount == 0 || str.equals(x)) { x = str; xCount++; continue; } nonXCount++; if (xCount == nonXCount) { answer++; xCount = 0; nonXCount = 0; } } if (xCount != nonXCount) { answer++; } return answer; } }
728x90'알고리즘' 카테고리의 다른 글
[프로그래머스] 뒤에있는 큰 수 찾기 (0) 2023.06.27 [프로그래머스] 옹알이2 (0) 2023.06.26 [프로그래머스] 숫자짝꿍 (0) 2023.06.23 [프로그래머스] 키패드 누르기(카카오 인턴) (0) 2023.06.22 [프로그래머스] 대충만든자판 (0) 2023.06.21