[4코1파] 4명의 안드로이드 개발자와 1명의 파이썬 개발자의 코딩 테스트 서막 : 4코1파

Rule :

하루에 1문제씩 풀기.
한 문제당 30분씩은 고민하기.
왜 그렇게 풀었는지 공유하기.
하루라도 놓친다면 벌금은 1,000원

START :

[3코1파] 2023.01.04~ (21일차)
[4코1파] 2023.01.13~ (12일차)

Today :

2023.01.24 [21일차]

프로그래머스 LV2.
올바른 괄호
https://school.programmers.co.kr/learn/courses/30/lessons/12909

문제 요약

괄호가 바르게 짝지어졌다는 것은 '(' 문자로 열렸으면 반드시 짝지어서 ')' 문자로 닫혀야 한다는 뜻입니다. 예를 들어
"()()" 또는 "(())()" 는 올바른 괄호입니다.
")()(" 또는 "(()(" 는 올바르지 않은 괄호입니다.
'(' 또는 ')' 로만 이루어진 문자열 s가 주어졌을 때, 문자열 s가 올바른 괄호이면 true를 return 하고, 올바르지 않은 괄호이면 false를 return 하는 solution 함수를 완성해 주세요.

제한 사항

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

입출력 예

문제 풀이 방법

문제 옆에 스택/큐가 되어있어서,,, 힌트를 얻어서
스택을 이용해서 풀면 될 것 같아서 했더니 됨
이게.. 되네 ?

내 코드

def solution(s):
    answer= True
    stack=[]
    for idx in s:
        if idx == '(':
            stack.append(idx)

        else:
            if stack==[]:
                answer = False
                break
            else: 
                stack.pop()

    if len(stack)!=0:
        answer= False
    return answer

증빙

여담

괄호 열어 아니 열지마 열어 아니 열지마
아악.....내일 출근해야돼

profile
꿈꾸는 것도 개발처럼 깊게

0개의 댓글