From 5f06e54159370195993381bd849df57b3850ef2e Mon Sep 17 00:00:00 2001 From: LiiNi-coder <97495437+LiiNi-coder@users.noreply.github.com> Date: Thu, 2 Oct 2025 23:46:43 +0900 Subject: [PATCH] =?UTF-8?q?[20251002]=20BOJ=20/=20G5=20/=20=EC=A1=B0=20?= =?UTF-8?q?=EC=A7=9C=EA=B8=B0=20/=20=EC=9D=B4=EC=9D=B8=ED=9D=AC?= MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit --- ...J \354\241\260\354\247\234\352\270\260.md" | 32 +++++++++++++++++++ 1 file changed, 32 insertions(+) create mode 100644 "LiiNi-coder/202510/02 BOJ \354\241\260\354\247\234\352\270\260.md" diff --git "a/LiiNi-coder/202510/02 BOJ \354\241\260\354\247\234\352\270\260.md" "b/LiiNi-coder/202510/02 BOJ \354\241\260\354\247\234\352\270\260.md" new file mode 100644 index 00000000..57152ae2 --- /dev/null +++ "b/LiiNi-coder/202510/02 BOJ \354\241\260\354\247\234\352\270\260.md" @@ -0,0 +1,32 @@ +```java +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[] arr = new int[N + 1]; + StringTokenizer st = new StringTokenizer(br.readLine()); + for(int i = 1; i <= N; i++) { + arr[i] = Integer.parseInt(st.nextToken()); + } + int[] dp = new int[N + 1]; + dp[0] = 0; + + for(int i = 1; i <= N; i++) { + dp[i] = 0; + int mx = arr[i]; + int mn = arr[i]; + for(int j = i; j >= 1; j--) { + mx = Math.max(mx, arr[j]); + mn = Math.min(mn, arr[j]); + dp[i] = Math.max(dp[i], dp[j-1] + (mx-mn)); + } + } + + System.out.println(dp[N]); + } +} + +```