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
- Special String Again
- 야근지수
- hackerrank
- Reverse Shuffle Merge
- Interview Preparation Kit
- 해커랭크
- Max Array Sum
- Common Child
- [sqld]자격증합격
- 프로그래머스
- candies
- Roads and Libraries
- 격파르타 후기
- 파이썬
- Find the nearest clone
- BFS: Shortest Reach in a Graph
- 격파르타 장점
- 격파르타 합격후기
- programmers
- 머신러닝
- Recursion: Davis' Staircase
- Algorithm
- DFS: Connected Cell in a Grid
- 백준
- 피보나치 함수
- 알고리즘
- 매칭점수
- 구슬탈출2
- 코딩테스트
Archives
- Today
- Total
Archive
[Hackerrank] [Medium] Candies 본문
https://www.hackerrank.com/challenges/candies/problem
풀이
- 2번 iteration을 사용.
- 오른쪽으로 iteration돌 때는 오름차순일 때 dp 값을 채워줌.
- 왼쪽으로 iteration돌 때는 내림차순일 때 dp값을 채워줌.
def candies(n, arr):
n = len(arr)
# 최소값은 1로 문제에서 주어짐.
dp = [1] * n
for i in range(1, n):
# 다음 원소가 더 크면 dp값을 증가해줌.
if arr[i-1] < arr[i]:
dp[i] += dp[i-1]
# 왼쪽으로 거꾸로 iteration
for i in range(n-2, -1, -1):
# 왼쪽 원소가 더 큰 경우, 그리고 현재 dp값이 작을 때 바로 다음 dp값에 1 더해주는걸로 update.
if arr[i] > arr[i+1] and dp[i] <= dp[i+1]:
dp[i] = dp[i+1] + 1
return sum(dp)
'공부 > Algorithm' 카테고리의 다른 글
[programmers] [Level3] 야근지수 (0) | 2020.09.01 |
---|---|
[Hackerrank] [Medium] Recursion: Davis' Staircase (0) | 2020.09.01 |
[Hackerrank] [Medium] Abbreviation (0) | 2020.09.01 |
[Hackerrank] [Medium] Max Array Sum (0) | 2020.08.31 |
[Hackerrank] [Hard] Reverse Shuffle Merge (0) | 2020.08.31 |
Comments