Problem Solving/Baekjoon
[백준] 25706 자전거 묘기 - Dynamic Programming / Java
graycode
2023. 5. 20. 15:19
• 문제 링크
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();
}
}