-
[백준 - 5557번] 1학년 - Java //Wello Horld //Algorithm/BOJ(Baekjoon Online Judge) 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
혹시 코드에 이상한 부분이나 틀린 부분이 있던지, 이해가 안가는 부분이 있다면 댓글로 알려주세요
'Algorithm > BOJ(Baekjoon Online Judge)' 카테고리의 다른 글
[백준 - 14681번] 사분면 고르기 - Java //Wello Horld // (0) 2020.04.17 [백준 - 7360번] Undercut - Java //Wello Horld // (0) 2020.04.16 [백준 - 14888번] 연산자 끼워넣기 - Java //Wello Horld // (0) 2020.04.14 [백준 - 4963번] 섬의 개수 - Java //Wello Horld // (0) 2020.04.13 [백준 - 9659번] 돌게임 5 - Java //Wello Horld // (0) 2020.04.10