[프로그래머스] level2. 괄호 회전하기

홈런볼·2023년 9월 7일

프로그래머스

목록 보기
34/36

문제링크

https://school.programmers.co.kr/learn/courses/30/lessons/76502

문제설명

다음 규칙을 지키는 문자열을 올바른 괄호 문자열이라고 정의합니다.

(), [], {} 는 모두 올바른 괄호 문자열입니다.
만약 A가 올바른 괄호 문자열이라면, (A), [A], {A} 도 올바른 괄호 문자열입니다. 예를 들어, [] 가 올바른 괄호 문자열이므로, ([]) 도 올바른 괄호 문자열입니다.
만약 A, B가 올바른 괄호 문자열이라면, AB 도 올바른 괄호 문자열입니다. 예를 들어, {} 와 ([]) 가 올바른 괄호 문자열이므로, {}([]) 도 올바른 괄호 문자열입니다.
대괄호, 중괄호, 그리고 소괄호로 이루어진 문자열 s가 매개변수로 주어집니다. 이 s를 왼쪽으로 x (0 ≤ x < (s의 길이)) 칸만큼 회전시켰을 때 s가 올바른 괄호 문자열이 되게 하는 x의 개수를 return 하도록 solution 함수를 완성해주세요.

제한사항

  • s의 길이는 1 이상 1,000 이하입니다.

입출력

sresult
"{}"3
"}]()[{"2
"[)(]"0
"}}}"0

로직

  1. 문자열 s를 반복하면서 s에 (), {}, [] 를 제거했을때 문자열 s가 빈값이 되는지 체크하는 isCheck 함수를 생성한다
  2. 문자열 s에 괄호가 있는지 체크하는 isCheck 함수를 통해 문자열 s가 괄호문자열인지 체크 후 answer 값을 증가시킨다
  3. 문자열s을 x칸 만큼 회전하면서 문자열 s를 새롭게 만들고, 올바른 괄호 문자열인지 체크 후 answer 값을 증가시킨다
  4. answer 값을 반환한다

코드

class Solution {
    public int solution(String s) {
        int answer = 0;

        if(isCheck(s)) answer++;
        for(int x=1;x<s.length();x++){
            //s 를 왼쪽으로 x 칸 만큼 회전
            s = s.substring(1) + s.charAt(0);
            // 올바른 괄호문자열
            if(isCheck(s)) answer ++;
        }
        return answer;
    }

    private static boolean isCheck(String s){
        int len = s.length()+1;
        while(len != s.length()){
            len = s.length();
            s = s.replace("()","");
            s = s.replace("{}","");
            s = s.replace("[]","");
        }
        return s.isEmpty();
    }
}

시간복잡도

O(n^2)

정확성 테스트

0개의 댓글