<Algorithm> 114. 2293번 동전1
by BFine반응형
1. 2293번 동전1
DP Memorization 문제
예전에 한번 풀어봤던 문제인데 바로 떠오르질 않았다. 다시풀어봐도 꽤 좋은 문제인 것 같다. 배열의 인덱스를 잘 활용해야겠다.
Stream으로 이중 loop를 만드는게 쉽지 않았다. Stream안에 Stream에서 변수가 공유가 안될줄 알았는데 해보니 잘됬고 람다를 조금씩 알아가는 것 같다.
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 | import java.io.BufferedReader; import java.io.IOException; import java.io.InputStreamReader; import java.util.StringTokenizer; import java.util.concurrent.atomic.AtomicInteger; import java.util.stream.IntStream; public class Main { public static void main(String[] args) throws IOException { BufferedReader br = new BufferedReader(new InputStreamReader(System.in)); StringTokenizer st = new StringTokenizer(br.readLine()); int n = Integer.parseInt(st.nextToken()); int k = Integer.parseInt(st.nextToken()); int[] coin = new int[n]; int[] dp = new int[k+1]; /****************************** * Memorization을 활용하여 DP로 * 가장 작은 동전부터 경우의 수를 모두 구한다. * 지금 동전을 사용하고 남은 액수에 대한 * 경우가 이미 Memorization 되있기 때문에 * 누적해서 최종 k까지의 경우의 수를 구할 수 있다. *******************************/ for(int i = 0; i < n; i++) { coin[i] = Integer.parseInt(br.readLine()); } dp[0] = 1; AtomicInteger atom = new AtomicInteger(0); IntStream.of(coin) .flatMap(i->IntStream.rangeClosed(0, k) .filter(j->{atom.set(i); return (j-i)>=0;})) .forEach(res->dp[res]+=dp[res-atom.get()]); System.out.println(dp[k]); } } | cs |
참고 & 출처
반응형
'공부(2018~2019) - 스킨변경전 > Algorithm' 카테고리의 다른 글
<Algorithm> 116. 보호필름(SWExpert) (0) | 2019.02.16 |
---|---|
<Algorithm> 115. 14890번 경사로 (0) | 2019.02.16 |
<Algorithm> 113. 1149번 RGB거리 (0) | 2019.02.15 |
<Algorithm> 112. 프로세서(SWExpert) (0) | 2019.02.15 |
<Algorithm> 111. 3055번 탈출 (0) | 2019.02.13 |
블로그의 정보
57개월 BackEnd
BFine