이 포스팅에서는 2020 카카오 블라인드 채용 1차 문제인 ‘괄호 변환’ 문제를 해설합니다. 본 풀이에 대한 테스트는 https://programmers.co.kr/learn/courses/30/lessons/60058에서 수행하였으며 공식 풀이와 일치하지 않을 수 있습니다.
공식 풀이는 링크를 참조하시기 바랍니다.
출처 : 2020 KAKAO 블라인드 채용 온라인 1차
링크 : https://programmers.co.kr/learn/courses/30/lessons/60058
카테고리 : 재귀 호출
난이도 : 쉬움
주어진 괄호 문자열을 올바른 괄호 문자열로 바꾸어 출력. 그 방법은 문제 설명에 같이 주어진다.
주어진대로 코드를 짜면 된다.
여기서 구현할 것은 ‘재귀 호출’, ‘균형 잡힌 문자열’ 판별, ‘올바른 문자열’ 판별이다.
균형 잡힌 문자열 판별은 맨 처음에 cnt를 0으로 초기화하고 문자열 가장 처음부터 순차적으로 읽어가면서 열기 괄호면 1을 더하고, 닫기 괄호면 1을 뺀다. 이후 cnt가 0인지 체크하여 0이면 종료한다.
올바른 문자열 판별은 균형 잡힌 문자열과 같은 방식으로 진행하되, cnt가 -1이 되는 순간이 존재한다면 올바르지 않는 것으로 판별하고, 그렇지 않으면 올바른 것으로 판별하면 된다.
def get_reverse(s): ret = “” for i in range(1, len(s) – 1): if s[i] == ‘(‘: ret += ‘)’ else: ret += ‘(‘ return ret def is_correct(s): cnt = 0 for c in s: if c == ‘(‘: cnt += 1 else: cnt –= 1 if cnt < 0: return False return True def do(s): if len(s) == 0: return “” i, cnt = 0, 0 while True: if s[i] == ‘(‘: cnt += 1 else: cnt –= 1 i += 1 if cnt == 0: break u, v = s[:i], s[i:] if is_correct(u): return u + do(v) else: return ‘(‘ + do(v) + ‘)’ + get_reverse(u) def solution(p): return do(p) | cs |
Competition 카카오 블라인드 채용 문자열 압축
AI AI Agent들이 어느 정도 유용한 건 맞지만, 생각보다 성능이 그렇게 시원찮은지는 모르겠다. 특히나 코드…
티앤미미 예약이 그렇게 힘들다는 티앤미미를 처남네가 운좋게 예약해서 어제 저녁 다녀왔다. 딤섬이 그렇게 맛있다고 하는데,…
아난티 부산 시설과 고객 서비스가 이렇게 극단적으로 다른 방향인 호텔이 있을까 싶다. 시설의 퀄리티는 5성급이라기에…
This website uses cookies.