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
- python
- hackerrank
- programmers
- Roads and Libraries
- 피보나치 함수
- 격파르타 합격후기
- 격파르타 후기
- 매칭점수
- 구슬탈출2
- 코딩테스트
- 프로그래머스
- Algorithm
- 알고리즘
- BFS: Shortest Reach in a Graph
- Find the nearest clone
- Special String Again
- Common Child
- Interview Preparation Kit
- [sqld]자격증합격
- Recursion: Davis' Staircase
- Max Array Sum
- candies
- 머신러닝
- Reverse Shuffle Merge
- 격파르타 장점
- 해커랭크
- DFS: Connected Cell in a Grid
- 파이썬
- 야근지수
- 백준
Archives
- Today
- Total
Archive
[Hackerrank] [Medium] Max Array Sum 본문
https://www.hackerrank.com/challenges/max-array-sum/problem
풀이
- 입력으로 정수로 구성된 arr를 받을 때, 이웃하지 않은 element와의 최대합을 구하는 문제
- n1, n2, n3 3개만 있고 swap해가면서 정답을 구할 수 있음.
- 보통 dp[i] = i번째 원소까지 봤을 때 최대합 으로 생각해 문제를 접근
- n2를 초기화할 때 arr[1]로 하지 말고 max(2번째 원소까지)
- 음수 값도 존재하기 때문에, i번째 원소가 최대인 경우도 있음.
- max 값을 update할 때 자기 자신이 최대인 경우도 생각해야 함.
def maxSubsetSum(arr):
if len(arr) == 1:
return arr[0]
n1, n2 = arr[0], max(arr[:2])
for a in arr[2:]:
n3 = max(n2, n1+a, a)
n1, n2 = n2, n3
return n3
'공부 > Algorithm' 카테고리의 다른 글
[Hackerrank] [Medium] Candies (0) | 2020.09.01 |
---|---|
[Hackerrank] [Medium] Abbreviation (0) | 2020.09.01 |
[Hackerrank] [Hard] Reverse Shuffle Merge (0) | 2020.08.31 |
[Hackerrank] [Medium] Common Child (0) | 2020.08.28 |
[Hackerrank] [Medium] Special String Again (0) | 2020.08.28 |
Comments