공부/프로그래머스

[프로그래머스 Lv. 2] 올바른 괄호 - JAVA

해니0 2024. 8. 12. 08:00

문제

괄호가 바르게 짝지어졌다는 것은 '(' 문자로 열렸으면 반드시 짝지어서 ')' 문자로 닫혀야 한다는 뜻입니다. 예를 들어

"()()" 또는 "(())()" 는 올바른 괄호입니다.
")()(" 또는 "(()(" 는 올바르지 않은 괄호입니다.
'(' 또는 ')' 로만 이루어진 문자열 s가 주어졌을 때, 문자열 s가 올바른 괄호이면 true를 return 하고, 올바르지 않은 괄호이면 false를 return 하는 solution 함수를 완성해 주세요.

 

제한사항

문자열 s의 길이 : 100,000 이하의 자연수
문자열 s는 '(' 또는 ')' 로만 이루어져 있습니다.

 

입출력 예

s answer
"()()" true
"(())()" true
")()(" false
"(()(" false


입출력 예 설명
입출력 예 #1,2,3,4
문제의 예시와 같습니다.


문제 풀이

분석

스택(Stack)은 LIFO(Last In, First Out) 구조로 가장 나중에 들어온 요소가 가장 먼저 나가는 특성

여는 괄호 (를 만나면 스택에 추가하고, 닫는 괄호 )를 만나면 스택에서 가장 최근에 추가된 여는 괄호를 제거하는 방식으로 접근

 

내 소스 코드

import java.util.Stack;

class Solution {
    public boolean solution(String s) {
        // 여는 괄호를 저장할 스택 초기화
        Stack<Character> stack = new Stack<>();

        // 문자열의 각 문자를 순회
        for (int i = 0; i < s.length(); i++) {
            char c = s.charAt(i);

            // 여는 괄호를 만나면 스택에 추가
            if (c == '(') {
                stack.push(c);
            }
            // 닫는 괄호를 만나면 스택에서 여는 괄호를 제거
            else if (c == ')') {
                // 스택이 비어 있으면 짝이 맞지 않음
                if (stack.isEmpty()) {
                    return false;
                }
                stack.pop(); // 가장 최근의 여는 괄호 제거
            }
        }

        // 모든 괄호의 짝이 맞는지 확인
        return stack.isEmpty();
    }
}

 

다른 풀이 1

스택을 사용하지 않는 방법

class Solution {
    boolean solution(String s) {
        boolean answer = false;
        int count = 0;
        for(int i = 0; i<s.length();i++){
            if(s.charAt(i) == '('){
                count++;
            }
            if(s.charAt(i) == ')'){
                count--;
            }
            if(count < 0){
                break;
            }
        }
        if(count == 0){
            answer = true;
        }

        return answer;
    }
}

 


Lv.2  / Java / 스택/큐

출처: 프로그래머스 코딩 테스트 연습, https://school.programmers.co.kr/learn/challenges