베어_
TechBear
베어_
전체 방문자
오늘
어제
  • 분류 전체보기 (336)
    • Spring (33)
      • 개념 (13)
      • Security (5)
      • 실습 (1)
      • 토비 스프링 (11)
    • JPA (6)
    • 프로젝트 기록 (24)
    • DB (13)
    • JAVA (18)
    • 알고리즘 (50)
      • 유형정리 (8)
      • Baekjoon (21)
      • LeetCode (18)
    • 디자인패턴 (0)
    • 개발서적 (79)
      • Effective Java (78)
      • 객체지향의 사실과 오해 (1)
    • 독후감 (4)
    • 보안 (2)
    • 운영체제(OS) (53)
      • 공룡책 (53)
    • 컴퓨터 네트워크 (28)
      • 컴퓨터 네트워크 하향식 접근 (23)
    • 자료구조 (1)
    • DevOps (2)
    • 앱 개발 (20)
      • 안드로이드 스튜디오 (20)

블로그 메뉴

    공지사항

    인기 글

    태그

    • 토비스프링
    • 이펙티브자바
    • BFS
    • java
    • 함수형인터페이스
    • Spring
    • 알고리즘
    • 데이터베이스
    • 운영체제
    • 스프링
    • 자바
    • 스프링시큐리티
    • C++
    • dfs
    • 자바8
    • 백준
    • leetcode
    • jpa
    • 코드업
    • 스레드

    최근 댓글

    최근 글

    티스토리

    hELLO · Designed By 정상우.
    베어_

    TechBear

    알고리즘/Baekjoon

    [백준] 2504 괄호의 값

    2022. 10. 19. 08:41

    ✉️문제

    https://www.acmicpc.net/problem/2504

     

    2504번: 괄호의 값

    4개의 기호 ‘(’, ‘)’, ‘[’, ‘]’를 이용해서 만들어지는 괄호열 중에서 올바른 괄호열이란 다음과 같이 정의된다. 한 쌍의 괄호로만 이루어진 ‘()’와 ‘[]’는 올바른 괄호열이다.  만일

    www.acmicpc.net

     

    📝 접근

    분배법칙을 이용하면 쉽게 풀 수 있다. 일단 stack과 Tmp 변수를 준비하자. 여기에 분배법칙을 한 값들을 더 해줄 예정이다.

    1. ‘(’이면 tmp변수에 2를 곱해준다.

    2. ‘[’이면 tmp변수에 3을 곱해준다.

    3. ‘)’일 때

            a. 만약 stack이 비어있거나, ‘(’가 아니면 잘못된 입력이므로 종료한다.

            b. 이전 문자가 ‘(’ 이면 answer에 tmp를 더 해준다.

    4. ‘]’일 때

        a. 만약 stack이 비어있거나, ‘[’가 아니면 잘못된 입력이므로 종료한다.

        b. 이전 문자가 ‘[’ 이면 answer에 tmp를 더 해준다.

     

    🗝 문제풀이

    package step2;
    
    import java.util.Scanner;
    import java.util.Stack;
    
    public class Q2504 {
    
        public static void main(String[] args) {
            Scanner sc = new Scanner(System.in);
    
            String input = sc.next();
    
            Stack<Character> stack = new Stack<>();
            int result = 0;
            int value = 1;
    
            for(int i = 0; i < input.length(); i++) {
                char cur = input.charAt(i);
    
                if(cur == '(') {
                    stack.push(cur);
                    value *= 2;
                    continue;
                }
    
                if(cur == '[') {
                    stack.push(cur);
                    value *= 3;
                    continue;
                }
    
                if(cur == ')') {
                    if(stack.isEmpty() || stack.peek() != '(') {
                        result = 0;
                        break;
                    }
    
                    if(input.charAt(i-1) == '(') {
                        result += value;
                    }
                    stack.pop();
                    value /= 2;
                    continue;
                }
    
                if(cur == ']') {
                    if(stack.isEmpty() || stack.peek() != '[') {
                        result = 0;
                        break;
                    }
    
                    if(input.charAt(i-1) == '[') {
                        result += value;
                    }
                    stack.pop();
                    value /= 3;
                }
            }
    
            if(!stack.isEmpty()) System.out.println(0);
            else System.out.println(result);
    
        }
    }
    저작자표시 비영리 변경금지
      '알고리즘/Baekjoon' 카테고리의 다른 글
      • [백준] 14719 빗물 (JAVA)
      • [백준] 17425 약수의 합2 (Java)
      • [백준] 17427 약수의 합 2
      • [백준] 1037 약수 (Java)
      베어_
      베어_
      Today I learned | 문제를 해결하는 개발자

      티스토리툴바