Notice
Recent Posts
Recent Comments
Tags
- 장고 기초
- Django 기초
- 백준
- 프로그래머스 레벨1
- 항해99 코테 스터디
- 항해99
- 코테 연습
- 프로그래머스
- BFS
- dp 알고리즘
- 백준 구현
- programmers
- spring 기초
- TIL
- 스프링 초보
- 백준 dp
- 프로그래머스 level1
- 브루트포스
- 이분탐색
- 백준 DFS와 BFS
- 스프링 기초
- 알고리즘 문제
- 99클럽 코테 스터디
- 백준 다이나믹프로그래밍
- 코딩테스트 연습
- 다이나믹 프로그래밍
- 코딩테스트
- 코테
- 알고리즘 공부
- Spring 초보
Archives
- Today
- Total
일일구름 IT
[백준 1912] 연속합 (Python) 본문
https://www.acmicpc.net/problem/1912
1912번: 연속합
첫째 줄에 정수 n(1 ≤ n ≤ 100,000)이 주어지고 둘째 줄에는 n개의 정수로 이루어진 수열이 주어진다. 수는 -1,000보다 크거나 같고, 1,000보다 작거나 같은 정수이다.
www.acmicpc.net
[문제]
[틀린 코드]
n = int(input())
num = list(map(int, input().split()))
arr = []
for i in range(1, n):
for j in range(0, n-i):
arr.append(sum(num[j:(j+i)]))
print(max(arr))
처음에는 리스트 슬라이싱을 이용해서 모든 경우를 구한 뒤 가장 합이 큰 경우를 출력하였다.
이렇게 문제를 푸니 테스트케이스는 맞지만 시간초과로 틀렸다.
그래서 다른 사람의 코드를 참고하여 풀게되었다.
[맞은 코드]
n = int(input())
num = list(map(int, input().split()))
for i in range(1, n):
num[i] = max(num[i-1]+num[i], num[i])
print(max(num))
전형적인 DP 알고리즘 코드였다.
앞의 수와 더한 값과 더하지 않은 값 중 더 큰 값을 저장하고 이를 계속 하면 결과가 누적되어 최종 결괏값을 알 수 있다.
'백준 > 다이나믹 프로그래밍' 카테고리의 다른 글
[백준 11052] 카드 구매하기 (Python) (0) | 2025.02.24 |
---|---|
[백준 2294] 동전2 (Python) (0) | 2023.05.08 |
[백준 2293] 코인1 (Python) (0) | 2023.05.08 |
[백준 1932] 정수 삼각형 (Python) (0) | 2023.03.23 |