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
- 협업
- Operating System
- 공부
- 기초100제
- CPU 스케줄링
- 일상
- memory
- C++
- OS
- 타입스크립트
- react
- 정렬
- js to ts
- 프로그래머스
- 자료구조
- 코드업
- codeup
- 백준
- 파이썬
- 알고리즘
- web
- Redux
- 토이프로젝트
- 리덕스장바구니
- Spring
- react-redux
- 스프링
- Java
- error
- 분할메모리할당
Archives
- Today
- Total
감자튀김 공장🍟
[백준/1912] 연속합 (with 파이썬) 본문
반응형
✔ 문제
✔ 풀이
import sys
input = sys.stdin.readline
n = int(input())
arr = [0] + list(map(int, input().split()))
dp = [-1001] * (n+1)
for i in range(1, n+1):
dp[i] = max(arr[i], dp[i-1] + arr[i])
print(max(dp))
✔ 설명
가장 큰 값을 구해야하기 때문에 이전까지의 합에 현재 숫자를 더한 값과 현재 위치의 값 중 더 큰 값을 dp에 저장한다.
✔ 후기
1개 이상의 연속된 수를 더해야한다고 하길래 arr에서 1개 합, 2개 합, 3개 합 이렇게 하나씩 다 구하고 값을 비교해야 한다고 생각했다. 분명 그렇게 구현되지 않을 것 같았는데 저 생각이 머리를 지배하고 있었다.
max도 사용한다는걸 어렴풋이 알고 있었지만 막상 어떤 값과 어떤 값을 비교해야 하는지 dp[i]의 i는 선택된 숫자들의 개수가 들어가는건지 꽤나 삽질했다.
반응형
'Algorithm > BOJ' 카테고리의 다른 글
[백준/1932] 정수 삼각형 (with 파이썬) (0) | 2023.02.14 |
---|---|
[백준/1149] RGB거리 (with 파이썬) (0) | 2023.02.13 |
[백준/9461] 파도반 수열 (with 파이썬) (0) | 2023.02.09 |
[백준/1904] 01타일 (with 파이썬) (0) | 2023.02.08 |
[백준/9184] 신나는 함수 실행 (with 파이썬) (0) | 2023.02.07 |
Comments