https://school.programmers.co.kr/learn/courses/30/lessons/76502
코딩테스트 연습 > 월간 코드 챌린지 시즌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;
}
}
'Algorithm > Programmers Java' 카테고리의 다른 글
[JAVA] 프로그래머스 LEVEL2 2개 이하로 다른 비트 (1) | 2024.10.16 |
---|---|
[JAVA] 프로그래머스 LEVEL2 n^2 배열 자르기 (1) | 2024.10.15 |
[JAVA] 프로그래머스 LEVEL2 튜플 (1) | 2024.10.14 |
[JAVA] 프로그래머스 LEVEL2 롤케이크 자르기 (1) | 2024.10.14 |
[JAVA] 프로그래머스 LEVEL2 이진 변환 반복하기 (0) | 2024.10.13 |