본문 바로가기
Problem Solving/Baekjoon

[백준] 25706 자전거 묘기 - Dynamic Programming / Java

by graycode 2023. 5. 20.

 문제 링크

 

25706번: 자전거 묘기

길이가 N미터인 직선 자전거 도로가 있다. 도로는 길이가 1미터인 N개의 칸으로 구분되어 있고, 가장 왼쪽에 있는 칸부터 순서대로 1번 칸, 2번 칸, …, N번 칸이다. 도로의 각 칸에는 점프대가 설

www.acmicpc.net

 

 풀이 과정

 

 풀이 코드

import java.io.BufferedReader;
import java.io.BufferedWriter;
import java.io.IOException;
import java.io.InputStreamReader;
import java.io.OutputStreamWriter;
import java.util.StringTokenizer;

public class Main {

    public static void main(String[] args) throws IOException {
        BufferedReader br = new BufferedReader(new InputStreamReader(System.in));
        BufferedWriter bw = new BufferedWriter(new OutputStreamWriter(System.out));

        int n = Integer.parseInt(br.readLine());
        StringTokenizer st = new StringTokenizer(br.readLine());

        int[] arr = new int[n];
        for (int i = 0; i < n; i++)
            arr[i] = Integer.parseInt(st.nextToken());

        int[] dp = new int[n];
        for (int i = n - 1; i >= 0; i--)
            dp[i] = i + arr[i] + 1 < n ? dp[i + arr[i] + 1] + 1 : 1;

        StringBuilder sb = new StringBuilder();
        for (int i : dp)
            sb.append(i).append(" ");

        bw.write(sb.toString());
        bw.flush();
    }

}

댓글