본문 바로가기
Algorithm/Programmers Java

[JAVA] 프로그래머스 LEVEL2 괄호 회전하기

by 제우제우 2024. 10. 14.

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

 

프로그래머스

코드 중심의 개발자 채용. 스택 기반의 포지션 매칭. 프로그래머스의 개발자 맞춤형 프로필을 등록하고, 나와 기술 궁합이 잘 맞는 기업들을 매칭 받으세요.

programmers.co.kr

코딩테스트 연습 > 월간 코드 챌린지 시즌2 > 괄호 회전하기

 

난이도: LEVEL2

알고리즘 유형: 구현

 

정답 코드 

import java.util.*;
class Solution {
    public int solution(String s) {
        Deque<Character> dq = new LinkedList<>();
        for(int i = 0; i < s.length(); i++){
            dq.addLast(s.charAt(i));   
        }
        int answer = 0;
        for(int i = 0; i < s.length(); i++){
            if(check(dq)) answer++;
            char front = dq.pollFirst();
            dq.addLast(front);
        }
        return answer;
    }
    public boolean check(Deque<Character> dq){
        Stack<Character> stack = new Stack<>();
        for(int i = 0; i < dq.size(); i++){
            char cur = dq.pollFirst();
            dq.addLast(cur);
            if(stack.isEmpty()) stack.push(cur);
            else{
                if(cur == '}' && stack.peek() == '{'){
                    stack.pop();
                }
                else if(cur == ']' && stack.peek() == '['){
                    stack.pop();
                }
                else if(cur == ')' && stack.peek() == '('){
                    stack.pop();
                }
                else{
                    stack.push(cur);
                }
            }
        }
        if(stack.isEmpty()) return true;
        return false;
    }
}