Notice
Recent Posts
Recent Comments
Link
일 | 월 | 화 | 수 | 목 | 금 | 토 |
---|---|---|---|---|---|---|
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 |
Tags
- 스프링 배치 메타 테이블
- git stage
- 스테이지에 올리기
- nonblocking
- 스프링 웹플럭스
- 날짜형을 문자형으로
- 무시하기
- 성능개선
- 마리아디비
- org.json
- 폐기하기
- JSON 분할
- batchInsert
- JSONObject 분할
- multi update
- ChainedTransactionManager #분산데이터베이스 #Spring Boot #MyBatis
- 마이바티스 트랜잭션
- JSONArray 분할
- 문자형을 날짜형으로
- str_to_date
- JSON 분해
- JobExecutionAlreadyRunningException
- date_format
- spring reactive programming
- jar 소스보기
- 스프링 리액티브 프로그래밍
- spring webflux
- JSON 분리
- 스프링 배치 공식문서
- Meta Table
Archives
- Today
- Total
ebson
boj.kr/11052 카드 구매하기 (silver1) 파이썬 풀이 본문
1. dp 배열을 N+1 * N+1 의 크기로 초기화한다.
2. dp[1][x] 값을 cards[1] * x 값으로 초기화한다.
3. dp[ci][ni] 값을 카드를 ci번째까지 검사했을 때 총 ni 개의 카드를 갖는 최대 가격으로 저장한다.
3.1. 이전 검사에서 ni개의 카드를 갖는 최대 가격 -> dp[ci-1][ni]
3.2 이전 검사에서 ni-ci개의 카드를 갖는 최대가격 + ci개에 해당하는 카드 가격 -> dp[ci-1][ni-ci] + cards[ci]
3.3. 현재 검사에서 ni-ci개의 카드를 갖는 최대가격 + ci개에 해당하는 카드 가격 -> dp[ci][ni-ci]+cards[ci] 를 비교하고
3.4. 현재 검사에서 ni-(1이상ni미만)개의 카드를 제외하는 경우의 최대 가격 + (1이상ni미만)개에 해당하는 카드 가격 -> dp[ci][ni-(1이상ni미만)]+cards[1이상ni미만] 값과 차례대로 비교해 최대값을 저장한다.
4. dp에서 최대값을 출력한다.
N = int(input())
cards = [0]+list(map(int, input().split()))
dp = [[0 for _ in range(N+1)] for _ in range(N+1)]
for _ in range(1, N+1):
dp[1][_] = cards[1]*_
for ci in range(2, len(cards)):
for ni in range(ci, N+1):
dp[ci][ni] = max(max(dp[ci-1][ni]
, dp[ci-1][ni-ci] + cards[ci])
, dp[ci][ni-ci]+cards[ci])
for _ in range(1, ni+1):
dp[ci][ni] = max(dp[ci][ni], dp[ci][ni-_]+cards[_])
ans = -1e9
for y in range(len(dp)):
for x in range(len(dp[y])):
ans = max(ans, dp[y][x])
print(ans)
dp[ci][ni] 값을 카드를 ci번째까지 검사했을 때 총 ni 개의 카드를 갖는 최대 가격으로 저장할 수 있다.
* Python3으로 제출하는 경우 시간초과가 발생하고 PyPy3으로 제출해야 통과한다.
'ALGORITHM STUDY WITH PYTHON > DP' 카테고리의 다른 글
boj.kr/2293 동전1 (gold5) 파이썬 풀이 (0) | 2023.06.11 |
---|---|
boj.kr/9465 스티커 (silver1) 파이썬 풀이 (0) | 2023.06.11 |
boj.kr/9251 LCS (gold5) 파이썬 풀이 (0) | 2023.06.10 |
boj.kr/2156 포도주 시식 (silver1) 파이썬 풀이 (0) | 2023.06.04 |
boj.kr/1932 정수 삼각형 (silver1) 파이썬 풀이 (0) | 2023.06.04 |
Comments