[실버 3] 2579번 계단 오르기

2025. 8. 8. 14:33·Coding Test/백준[JAVA]

문제

계단 오르기 게임은 계단 아래 시작점부터 계단 꼭대기에 위치한 도착점까지 가는 게임이다. <그림 1>과 같이 각각의 계단에는 일정한 점수가 쓰여 있는데 계단을 밟으면 그 계단에 쓰여 있는 점수를 얻게 된다.

<그림 1>

 

예를 들어 <그림 2>와 같이 시작점에서부터 첫 번째, 두 번째, 네 번째, 여섯 번째 계단을 밟아 도착점에 도달하면 총 점수는 10 + 20 + 25 + 20 = 75점이 된다.

<그림 2>

계단 오르는 데는 다음과 같은 규칙이 있다.

  1. 계단은 한 번에 한 계단씩 또는 두 계단씩 오를 수 있다. 즉, 한 계단을 밟으면서 이어서 다음 계단이나, 다음 다음 계단으로 오를 수 있다.
  2. 연속된 세 개의 계단을 모두 밟아서는 안 된다. 단, 시작점은 계단에 포함되지 않는다.
  3. 마지막 도착 계단은 반드시 밟아야 한다.

따라서 첫 번째 계단을 밟고 이어 두 번째 계단이나, 세 번째 계단으로 오를 수 있다. 하지만, 첫 번째 계단을 밟고 이어 네 번째 계단으로 올라가거나, 첫 번째, 두 번째, 세 번째 계단을 연속해서 모두 밟을 수는 없다.

각 계단에 쓰여 있는 점수가 주어질 때 이 게임에서 얻을 수 있는 총 점수의 최댓값을 구하는 프로그램을 작성하시오.

 

입력

입력의 첫째 줄에 계단의 개수가 주어진다.

둘째 줄부터 한 줄에 하나씩 제일 아래에 놓인 계단부터 순서대로 각 계단에 쓰여 있는 점수가 주어진다. 계단의 개수는 300이하의 자연수이고, 계단에 쓰여 있는 점수는 10,000이하의 자연수이다.

 

출력

첫째 줄에 계단 오르기 게임에서 얻을 수 있는 총 점수의 최댓값을 출력한다.

 

예제 입력 1 

6
10
20
15
25
10
20

 

예제 출력 1 

75

 


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));
        int N = Integer.parseInt(br.readLine()); // 계단 개수
		
		int[] scores = new int[N + 1];
		int[] dp = new int[N + 1];
		
		for(int i=1; i<=N; i++) {
			scores[i] = Integer.parseInt(br.readLine());
		}
		
		dp[1] = scores[1]; // 첫 번째 계단 점수
		if(N >= 2) dp[2] = scores[1] + scores[2]; // 두 번째 계단 점수
		
		for(int i=3; i<=N; i++) {
			// dp[i-2] + scores[i] : i-2 계단에서 바로 두 계단 점프하여 i 계단으로 오르는 경우
			// dp[i-3] + scores[i-1] + scores[i] : i-3 계단에서 i-1 계단으로 한 계단 점프, 그리고 i 계단으로 한 계단 점프하는 경우
			dp[i] = Math.max(dp[i-2], dp[i-3] + scores[i-1]) + scores[i];
		}
		
        System.out.println(dp[N]);
        
        br.close();
    }
}
저작자표시 비영리 변경금지 (새창열림)

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

[실버 3] 1463번 1로 만들기  (2) 2025.08.08
[골드 4] 1253번 좋다  (1) 2025.06.19
[실버 4] 1940번 주몽  (0) 2025.06.19
[실버 5] 2018번 수들의 합 5  (0) 2025.06.19
[골드 3] 10986번 나머지 합  (0) 2025.06.19
'Coding Test/백준[JAVA]' 카테고리의 다른 글
  • [실버 3] 1463번 1로 만들기
  • [골드 4] 1253번 좋다
  • [실버 4] 1940번 주몽
  • [실버 5] 2018번 수들의 합 5
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)
  • 블로그 메뉴

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

  • 태그

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

  • hELLO· Designed By정상우.v4.10.0
woojin._.
[실버 3] 2579번 계단 오르기
상단으로

티스토리툴바