https://www.acmicpc.net/problem/2851
1. 아이디어
누적합을 활용한 브루트포스 알고리즘으로 해결할 수 있다.
2. 문제풀이
슈퍼 마리오는 처음부터 중단하기 전까지 버섯을 집어야하므로 이를 누적합 배열로 구했다. 누적합을 구하면서 바로 브루트포스 알고리즘으로 정답 및 100과의 차이를 저장하는 ans, diff 변수를 활용해서 100과의 차이의 절댓값이 더 작으면 해당 수를 정답으로 하고 절댓값이 같으면 정답과 해당 수 중 더 큰 수를 저장하도록 구현했다.
3. 코드
import java.io.*;
public class Main {
public static void main(String[] args) throws IOException {
BufferedReader br = new BufferedReader(new InputStreamReader(System.in));
int[] arr = new int[10];
for (int i = 0; i < 10; i++) {
arr[i] = Integer.parseInt(br.readLine());
}
int ans = 0;
int diff = 100;
int[] dp = new int[1 + 10];
for (int i = 1; i <= 10; i++) {
dp[i] = dp[i - 1] + arr[i - 1];
if ((Math.abs(dp[i] - 100) < diff) || (Math.abs(dp[i] - 100) == diff && (dp[i] > ans))) {
ans = dp[i];
diff = Math.abs(dp[i] - 100);
}
}
System.out.println(ans);
}
}
4. 후기
'코딩테스트 준비 > 백준' 카테고리의 다른 글
[백준] 2525번 - 오븐 시계 [Java] (0) | 2025.01.17 |
---|---|
[백준] 2501번 - 약수 구하기 [Java] (0) | 2025.01.17 |
[백준] 2869번 - 달팽이는 올라가고 싶다 [Java] (0) | 2025.01.17 |
[백준] 10811번 - 바구니 뒤집기 [Java] (0) | 2025.01.17 |
[백준] 2935번 - 소음 [Java] (0) | 2025.01.16 |