프로그래머스 - 괄호 변환 (javascript) [2020카카오공채]

김태은·2020년 1월 15일
3

문제풀이

목록 보기
4/12
function solution(p) {
	let answer = "";
	let left = 0 // 현재 왼쪽 괄호 개수
    let right = 0; // 현재 오른쪽 괄호 개수
	let check = false; // '올바른 괄호' 인지 아닌지
    
	if (p.length == 0) {
        return ""
    }
    
	for (let i = 0; i < p.length; i++) {
        
		if (p[i] == '(') left++;
		if (p[i] == ')') right++;
        
        // 핵심개념 : 오른쪽 괄호가 왼쪽 괄호의 수를 넘으면 그때부터 '올바른 괄호' X
		if (right > left) check = true;
        
        // 균형잡힌 u가 나와서 쪼갤 타이밍 (u,v)
		if (left == right) { 
          
            // '올바른 괄호' X
			if (check == true) {
				answer += '(';
				answer += solution(p.slice(i + 1, p.length));
				answer += ')';
              
                // 첫번째, 마지막 문자 제거하고 나머지 반전 후 뒤에 붙이기
				for (let j = 1; j < i; j++) {
					if (p[j] == ')') answer += '(';
					if (p[j] == '(') answer += ')';
				}
				return answer;
			}
            
            // '올바른 괄호' O
			else { 
				answer += p.slice(0, i + 1); // 그냥 넣고
				answer += solution(p.slice(i + 1, p.length)); // 나머지에 대해 재귀
				return answer;
			}
		}
    }
}
profile
프론트엔드 개발 공부블로그

0개의 댓글