๐ŸŒท๐ŸŒผ๋ชจ์—ฌ๋ด์š” ๊ฐœ๋ฐœ์˜์ˆฒ๐ŸŒท๐ŸŒผ

[JAVA/์ฝ”๋”ฉํ…Œ์ŠคํŠธ] ์˜ฌ๋ฐ”๋ฅธ ๊ด„ํ˜ธ ๋ณธ๋ฌธ

๊ฐœ๋ฐœ/์•Œ๊ณ ๋ฆฌ์ฆ˜ ๋ฌธ์ œํ’€์ด JAVA

[JAVA/์ฝ”๋”ฉํ…Œ์ŠคํŠธ] ์˜ฌ๋ฐ”๋ฅธ ๊ด„ํ˜ธ

์š”์ผ์ด 2021. 5. 26. 22:52
๋ฐ˜์‘ํ˜•

 

์„ค๋ช…

๊ด„ํ˜ธ๊ฐ€ ์ž…๋ ฅ๋˜๋ฉด ์˜ฌ๋ฐ”๋ฅธ ๊ด„ํ˜ธ์ด๋ฉด “YES", ์˜ฌ๋ฐ”๋ฅด์ง€ ์•Š์œผ๋ฉด ”NO"๋ฅผ ์ถœ๋ ฅํ•ฉ๋‹ˆ๋‹ค.

(())() ์ด๊ฒƒ์€ ๊ด„ํ˜ธ์˜ ์Œ์ด ์˜ฌ๋ฐ”๋ฅด๊ฒŒ ์œ„์น˜ํ•˜๋Š” ๊ฑฐ์ง€๋งŒ, (()()))์€ ์˜ฌ๋ฐ”๋ฅธ ๊ด„ํ˜ธ๊ฐ€ ์•„๋‹ˆ๋‹ค.

์ž…๋ ฅ

์ฒซ ๋ฒˆ์งธ ์ค„์— ๊ด„ํ˜ธ ๋ฌธ์ž์—ด์ด ์ž…๋ ฅ๋ฉ๋‹ˆ๋‹ค. ๋ฌธ์ž์—ด์˜ ์ตœ๋Œ€ ๊ธธ์ด๋Š” 30์ด๋‹ค.

์ถœ๋ ฅ

์ฒซ ๋ฒˆ์งธ ์ค„์— YES, NO๋ฅผ ์ถœ๋ ฅํ•œ๋‹ค.

 

์˜ˆ์‹œ ์ž…๋ ฅ 1  ์˜ˆ์‹œ ์ถœ๋ ฅ 1
(()(()))(() NO

 

 

import java.util.*;

public class Main {
	
	public String solution(String str) {
	
		String result = "YES";
		
		Stack<Character> stack = new Stack<>();
		
		for(char x : str.toCharArray()) {
			if(x == '(') {
				stack.push(x);
			}else {
				// ๋‹ซ๋Š” ๊ด„ํ˜ธ๊ฐ€ ๋งŽ์„๊ฒฝ์šฐ ์ด๊ณณ์—์„œ ๊ฑธ๋ฆผ ')'
				if(stack.isEmpty()) {
					return "NO";
				}
				stack.pop();
			}
		}
		// ์—ฌ๋Š” ๊ด„ํ˜ธ๊ฐ€ ๋งŽ์„๊ฒฝ์šฐ ์ด๊ณณ์—์„œ ๊ฑธ๋ฆผ '('
		if(!stack.isEmpty()) {
			result = "NO";
		}
		
		return result;
	}

	public static void main(String args[]) {
        Main main = new Main();
		Scanner in= new Scanner(System.in);
        
		String str = in.nextLine();
		
        System.out.print(main.solution(str));
    }

}
Comments