Algorithm

[Programmers] 괄호 변환

프로그래민 2020. 9. 3. 22:25
반응형

2020 카카오 문제였다.

이 문제는 옳은 괄호를 찾는 문제인데, 재귀를 이용해서 푸는 문제였다. 다만 이 문제에서는 재귀의 모든 과정을 문제에서 제공해주었고, 단순 구현만 하면 되는 문제였다. 따라서 문제의 제공되어있는데로 그대로 재귀를 구현하여 쉽게 풀 수 있었다.

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
package programmers2;
 
public class Solution_2020카카오_괄호변환 {
    public static void main(String[] args) {
        String p = "(()())()";
//        String p = ")(";
//        String p = "()))((()()";
//        String p = "))((";
        System.out.println(solution(p));
    }
    
    static String solution(String p) {
        
            
        String answer=func(p);
        
        
        return answer;
    }
    
    static String  func(String p) {
        if(p=="")
            return "";
        String[] split=split(p);
        String u=split[0];
        String v=split[1];
        
        if(check(u)==true) {
            return u+func(v);
        }
        
        String str="(";
        
        str+=func(v);
        
        str+=")";
        
        String temp="";
        for(int i=0;i<u.length();i++){
            if(i==0 || i==u.length()-1)
                continue;
            if(u.charAt(i)=='(')
                temp+=")";
            else
                temp+="(";
        }        
        str=str+temp;
        return str;
    }
    
    
    static boolean check(String str) {
        int check=0;
        for(int i=0;i<str.length();i++) {
            if(str.charAt(i)=='(') {
                check++;
            }else
                check--;
            
            if(check<0)
                return false;
        }
        return true;
    }
    
    static String[] split(String str) {
//        System.out.println(str+",,,");
        if(str.length()==0) {
            String[] answer=new String[2];
            
            answer[0="";
            answer[1]= "";
            
            return answer;
        }
        int sum=0;
        int check=0;
        for(int i=0;i<str.length();i++) {
            if(str.charAt(i)=='(') {
                sum++;
            }else {
                sum--;
            }
            if(sum==0) {
                check=i;
                break;
            }
        }
        String[] answer=new String[2];
        
        answer[0=str.substring(0,check+1);
        answer[1]= str.substring(check+1,str.length());
        
        return answer;
    }
}
 
                                                                               
반응형

'Algorithm' 카테고리의 다른 글

[Programmers] 방금그곡  (0) 2020.09.04
[BOJ] 1786. 찾기  (0) 2020.09.04
[BOJ] 2293. 동전 1  (0) 2020.09.02
[Programmers] 경주로 건설  (0) 2020.08.31
[Programmers] 보석 쇼핑  (0) 2020.08.31