Algorithm/BOJ(Baekjoon Online Judge)
[백준 - 5557번] 1학년 - Java //Wello Horld //
koucop
2020. 4. 15. 11:57
이번에는 BOJ의 5557번 문제 "1학년" 을 풀어보도록 하자
성공한 코드는 다음과 같다.
import java.io.*;
import java.util.*;
public class Main {
public static void main(String[] args) throws Exception {
BufferedReader br = new BufferedReader(new InputStreamReader(System.in));
BufferedWriter bw = new BufferedWriter(new OutputStreamWriter(System.out));
int N = Integer.parseInt(br.readLine());
int[] arr = new int[N];
StringTokenizer st = new StringTokenizer(br.readLine());
for(int i = 0; i < N; i++){
arr[i] = Integer.parseInt(st.nextToken());
}
long[][] dp = new long[N - 1][21];
dp[0][arr[0]] = 1;
for(int i = 1; i < N - 1; i++){
for(int j = 0; j < 21; j++){
if(dp[i - 1][j] != 0) {
if(j + arr[i] <= 20) dp[i][j + arr[i]] += dp[i - 1][j];
if(j - arr[i] >= 0) dp[i][j - arr[i]] += dp[i - 1][j];
}
}
}
bw.write(dp[N - 2][arr[N - 1]] + "\n");
bw.flush();
br.close();
bw.close();
}
}
문제 : https://www.acmicpc.net/problem/5557
5557번: 1학년
문제 상근이가 1학년 때, 덧셈, 뺄셈을 매우 좋아했다. 상근이는 숫자가 줄 지어있는 것을 보기만 하면, 마지막 두 숫자 사이에 '='을 넣고, 나머지 숫자 사이에는 '+' 또는 '-'를 넣어 등식을 만들며 놀고 있다. 예를 들어, "8 3 2 4 8 7 2 4 0 8 8"에서 등식 "8+3-2-4+8-7-2-4-0+8=8"을 만들 수 있다. 상근이는 올바른 등식을 만들려고 한다. 상근이는 아직 학교에서 음수를 배우지 않았고, 20을 넘는 수는 모른다.
www.acmicpc.net
혹시 코드에 이상한 부분이나 틀린 부분이 있던지, 이해가 안가는 부분이 있다면 댓글로 알려주세요