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
- programmers
- 야근지수
- Special String Again
- candies
- Algorithm
- python
- Roads and Libraries
- Find the nearest clone
- BFS: Shortest Reach in a Graph
- 격파르타 후기
- 해커랭크
- Max Array Sum
- 프로그래머스
- hackerrank
- 매칭점수
- Reverse Shuffle Merge
- 파이썬
- 백준
- Recursion: Davis' Staircase
- 구슬탈출2
- [sqld]자격증합격
- 머신러닝
- 알고리즘
- 피보나치 함수
- 격파르타 합격후기
- 격파르타 장점
- Common Child
- DFS: Connected Cell in a Grid
- 코딩테스트
- Interview Preparation Kit
Archives
- Today
- Total
Archive
[Hackerrank] [Hard] Maximum Subarray Sum 본문
https://www.hackerrank.com/challenges/maximum-subarray-sum/problem
풀이
- Input : 숫자 배열 arr, 나눌 수 m
- subarray : arr[ i : j ] index i부터 j까지 연속된 배열
- 문제 : subarray의 수를 다 더하고, m으로 나누었을 때 나머지의 최댓값 구하기.
- 모든 경우의 수를 다 해보는 O(N^2) 은 당연히 timeout
- $P_{i}$ : 0 ~ i번째 index까지 수를 더한 뒤, m으로 나누었을 때의 나머지
- $S_{i+1, j}$ : arr의 index ( i + 1)에서 j 까지의 subarray 합을 구한 뒤 M으로 나눴을 때의 나머지
- $S_{i+1, j} = (P_j - P_i + M)\%M$
- 왜 저 식이 동작하는지는 직접 구해보면 알수 있음.
- $P_j - P_i$ 에 M 을 더해줌으로써 결과가 항상 양수가 되도록 함.( M%M 을 하게 되면 0이기 때문에 더해줘도 상관 없음. )
- 위 식에서 나올 수 있는 최댓값을 생각해내는게 어려웠음.
- 언제 최대? $P_j - P_i = -1$ 일 때, $P_j - P_i + M = M-1$ 이 되므로, 나머지가 $M-1$ 로 최대가 되고, -1이 아니라면, $P_i가 P_j$ 보다 바로 다음 큰 수가 되면 됨. 이 부분은 아래 코드에서 bisect 라이브러리를 사용해 구현.
def maximumSum(arr, mod):
import bisect
# p_i를 정렬해서 저장.
sort_p_i = []
result = 0
cur = 0
for i in range(len(arr)):
# P_i를 계산
# 이전 결과 값을 항상 저장하고 있어야 함.
cur = (cur + arr[i]) % mod
# sort_p_i에서 현재 p_i가 들어갈 위치를 찾음
pos = bisect.bisect(sort_p_i, cur)
# sort_p_i의 모든 원소보다 p_i가 크다면 p==i가 됨.
# 그렇지 않고, sort_p_i 중간에 p_i가 들어가게 됨 -> p_i가 들어가게 되는 index 바로 다음 큰 수와의 차이를 계산
d = 0 if pos == i else sort_p_i[pos]
# d = 0인 경우, (cur+mod)%mod가 되는데, mod%mod = 0이므로, cur%mod가 됨.
# 하지만 d = sort_p_i[pos]이면, pos는 cur 다음 큰 수의 index가 되고, d는 cur 바로 다음 큰 수를 나타냄.
# bisect.bisect([1, 2, 5], 4) -> 2
result = max(result, (cur - d + mod) % mod)
# sort_p_i에 정렬된 상태를 유지하며 삽입.
bisect.insort(sort_p_i, cur)
return result
'공부 > Algorithm' 카테고리의 다른 글
[programmers] Level4. 도둑질 (0) | 2020.08.16 |
---|---|
[Hackerrank] [Medium] New Year Chaos (0) | 2020.08.12 |
[Hackerrank] pairs (0) | 2020.08.10 |
[Hackerrank] Triple sum (0) | 2020.08.10 |
[Hackerrank] Hash Tables: Ice Cream Parlor (0) | 2020.08.10 |
Comments