[실버 4] 4949번 균형잡힌 세상

2023. 9. 30. 19:29·Coding Test/백준[JAVA]

문제 링크 : https://www.acmicpc.net/problem/4949

문제

세계는 균형이 잘 잡혀있어야 한다. 양과 음, 빛과 어둠 그리고 왼쪽 괄호와 오른쪽 괄호처럼 말이다.

정민이의 임무는 어떤 문자열이 주어졌을 때, 괄호들의 균형이 잘 맞춰져 있는지 판단하는 프로그램을 짜는 것이다.

문자열에 포함되는 괄호는 소괄호("()") 와 대괄호("[]")로 2종류이고, 문자열이 균형을 이루는 조건은 아래와 같다.

모든 왼쪽 소괄호("(")는 오른쪽 소괄호(")")와만 짝을 이뤄야 한다.
모든 왼쪽 대괄호("[")는 오른쪽 대괄호("]")와만 짝을 이뤄야 한다.
모든 오른쪽 괄호들은 자신과 짝을 이룰 수 있는 왼쪽 괄호가 존재한다.
모든 괄호들의 짝은 1:1 매칭만 가능하다. 즉, 괄호 하나가 둘 이상의 괄호와 짝지어지지 않는다.
짝을 이루는 두 괄호가 있을 때, 그 사이에 있는 문자열도 균형이 잡혀야 한다.
정민이를 도와 문자열이 주어졌을 때 균형잡힌 문자열인지 아닌지를 판단해보자.

입력

각 문자열은 마지막 글자를 제외하고 영문 알파벳, 공백, 소괄호("( )"), 대괄호("[ ]")로 이루어져 있으며, 온점(".")으로 끝나고, 길이는 100글자보다 작거나 같다.

입력의 종료조건으로 맨 마지막에 온점 하나(".")가 들어온다.

출력

각 줄마다 해당 문자열이 균형을 이루고 있으면 "yes"를, 아니면 "no"를 출력한다.

예제 입력 1
So when I die (the [first] I will see in (heaven) is a score list).
[ first in ] ( first out ).
Half Moon tonight (At least it is better than no Moon at all].
A rope may form )( a trail in a maze.
Help( I[m being held prisoner in a fortune cookie factory)].
([ (([( [ ] ) ( ) (( ))] )) ]).
.
.

예제 출력 1
yes
yes
no
no
no
yes
yes

코드

import java.io.*;
import java.util.*;

public class Main {

	public static void main(String[] args) throws IOException {
		BufferedReader br = new BufferedReader(new InputStreamReader(System.in));
		StringBuilder sb = new StringBuilder();
		
		while(true) {
			String s = br.readLine();
			Stack<Character> stack = new Stack<Character>();
			
			if(s.equals(".")) break;  // .인 경우 중단
			
			for(int i=0; i<s.length(); i++) { // 문자열 하나씩 검사
				char ch = s.charAt(i);
				
				if(ch == '(' || ch == '[') stack.push(ch);  // 여는 괄호인 경우 넣기
				
				if(ch == ')') {  // 1번 닫기 괄호인 경우
					if(stack.isEmpty()) { // 스택이 비어있는 경우 넣기
						stack.push(ch);
						break;
					}
					
					if(stack.peek() == '(') stack.pop(); // 마지막 괄호가 여는 괄호인 경우 그 괄호 빼기
					else break;
					
				} else if(ch == ']') {  // 2번 닫기 괄호인 경우
					if(stack.isEmpty()) { // 스택이 비어있는 경우 넣기
						stack.push(ch);
						break;
					}
					
					if(stack.peek() == '[') stack.pop(); // 마지막 괄호가 여는 괄호인 경우 그 괄호 빼기
					else break;
					
				}
			}
			
			if(stack.isEmpty()) sb.append("yes").append("\n");
			else sb.append("no").append("\n");
		}
		System.out.println(sb);
	}
}
저작자표시 비영리 변경금지 (새창열림)

'Coding Test > 백준[JAVA]' 카테고리의 다른 글

[실버 3] 24511번 queuestack  (0) 2023.10.02
[실버 3] 12789번 도키도키 간식드리미  (0) 2023.09.30
[실버 4] 9012번 괄호  (0) 2023.09.30
[실버 3] 2346번 풍선 터뜨리기  (0) 2023.09.30
[실버 5] 11866번 요세푸스 문제 0  (0) 2023.09.30
'Coding Test/백준[JAVA]' 카테고리의 다른 글
  • [실버 3] 24511번 queuestack
  • [실버 3] 12789번 도키도키 간식드리미
  • [실버 4] 9012번 괄호
  • [실버 3] 2346번 풍선 터뜨리기
woojin._.
woojin._.
여러가지 개발을 해보며 발생하는 이야기들에 대한 블로그입니다:)
  • woojin._.
    Jin's Dev Story
    woojin._.
  • 전체
    오늘
    어제
    • 분류 전체보기 (829)
      • Tools (25)
        • eGovFrame (3)
        • GeoServer (3)
        • QGIS (2)
        • LabelImg (2)
        • Git (6)
        • GitHub (1)
        • Eclipse (7)
        • Visual Studio (1)
      • Web & Android (121)
        • SpringBoot (37)
        • Three.js (2)
        • Spring Data JPA (9)
        • 스프링 부트 쇼핑몰 프로젝트 with JPA (25)
        • Thymeleaf (4)
        • Spring Security (15)
        • Flutter (29)
      • Programming Language (61)
        • JAVA (27)
        • JavaScript (14)
        • Dart (2)
        • Python (15)
        • PHP (3)
      • Database (43)
        • PostgreSQL (32)
        • MYSQL (7)
        • Oracle (3)
        • MSSQL (1)
      • SERVER (17)
        • TCP_IP (3)
        • 리눅스 (7)
        • AWS (7)
      • Coding Test (445)
        • 백준[JAVA] (108)
        • 프로그래머스[JAVA] (260)
        • 알고리즘 고득점 Kit[JAVA] (3)
        • SQL 고득점 Kit[ORACLE] (74)
      • CS 지식 (49)
        • [자료구조] (14)
        • [네트워크] (12)
        • [데이터베이스] (10)
        • [알고리즘] (9)
        • [운영체제] (4)
      • 기타 (6)
      • 자격증 & 공부 (62)
        • 정보처리기사 (2)
        • SQLD (6)
        • 네트워크관리사 2급 (5)
        • 리눅스마스터 1급 (44)
        • 리눅스마스터 2급 (1)
        • ISTQB (3)
        • 시스템보안 (1)
  • 블로그 메뉴

    • 홈
    • 태그
    • 방명록
  • 인기 글

  • 태그

    백준
    플러터
    데이터
    baekjoon
    Flutter
    DB
    자바
    Linux
    리눅스마스터
    스프링부트
    Java
    시큐리티
    spring
    postgresql
    프로그래머스
    programmers
    python
    JPA
    pcce 기출문제
    Spring Security
    springboot
    스프링 부트 쇼핑몰 프로젝트 with JPA
    스프링
    리눅스마스터 1급
    리눅스
    데이터베이스
    backjoon
    Oracle
    CS지식
    CS
  • 최근 글

  • hELLO· Designed By정상우.v4.10.0
woojin._.
[실버 4] 4949번 균형잡힌 세상
상단으로

티스토리툴바