본문 바로가기
Problem Solving/Baekjoon

[백준] 4097 수익 - Dynamic Programming / Java

by graycode 2023. 4. 4.

 문제 링크

 

4097번: 수익

입력은 여러 개의 테스트 케이스로 이루어져 있다. 각 테스트 케이스의 첫째 줄에는 N이 주어져 있다. (1 ≤ N ≤ 250,000) 둘째 줄부터 N개의 줄에는 매일 매일의 수익 P가 주어진다. (-10,000 ≤ P ≤ 10

www.acmicpc.net

 

 풀이 과정

 

 풀이 코드

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

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));

        StringBuilder sb = new StringBuilder();
        String input;
        while (!(input = br.readLine()).equals("0")) {
            int n = Integer.parseInt(input);

            int[] dp = new int[n + 1];
            int max = -10000;
            for (int i = 1; i <= n; i++) {
                int p = Integer.parseInt(br.readLine());
                dp[i] = Math.max(p, dp[i - 1] + p);

                max = Math.max(max, dp[i]);
            }

            sb.append(max).append("\n");
        }

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

}

댓글