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
- Find the nearest clone
- Reverse Shuffle Merge
- Roads and Libraries
- Special String Again
- Max Array Sum
- 해커랭크
- Algorithm
- hackerrank
- 코딩테스트
- 머신러닝
- candies
- 백준
- 구슬탈출2
- 격파르타 장점
- 파이썬
- Interview Preparation Kit
- python
- 격파르타 합격후기
- Common Child
- 피보나치 함수
- 알고리즘
- 프로그래머스
- 매칭점수
- BFS: Shortest Reach in a Graph
- 격파르타 후기
- Recursion: Davis' Staircase
- DFS: Connected Cell in a Grid
- 야근지수
- programmers
- [sqld]자격증합격
Archives
- Today
- Total
Archive
[Hackerrank] [Medium] New Year Chaos 본문
https://www.hackerrank.com/challenges/new-year-chaos/forum
풀이
- Input : 1 이상의 정수로 구성된 list
- 순번이 뒤에 있는 사람이 바로 앞 사람에게 뇌물을 줌으로써 순서를 바꿀 수 있음.
- 한 사람이 사용할 수 있는 최대 뇌물은 2. -> 한 숫자마다 최대 2번 swapping
- 모든 경우의 수를 구하거나, 리스트 값을 덮어씌우거나 새로운 저장공간을 할당해 현황을 매번 저장할 필요 없음.
- 뇌물을 받은 개수만 counting해서 풀어도 됨.
def minimumBribes(q):
move = 0
# enumerate로 시작하는 index와 q의 값과 같게 해주기 위해 1씩 빼줌
Q = [i-1 for i in q]
for idx, person in enumerate(Q):
# index와 val의 차이가 2보다 크면 최대 swapping 수 2를 초과.
if person - idx > 2:
print("Too chaotic")
return
# person이 얼마나 뇌물을 받았는지 검사.
# 최대 뇌물 수가 2이기 때문에, person보다 큰 값이 바로 앞까지만 올 수 있음(두칸 앞이면 Too chaotic)
for j in range(max(person-1,0), idx):
if Q[j] > person:
move += 1
print(move)
'공부 > Algorithm' 카테고리의 다른 글
[programmers] Level4. 자동완성 (0) | 2020.08.17 |
---|---|
[programmers] Level4. 도둑질 (0) | 2020.08.16 |
[Hackerrank] [Hard] Maximum Subarray Sum (0) | 2020.08.11 |
[Hackerrank] pairs (0) | 2020.08.10 |
[Hackerrank] Triple sum (0) | 2020.08.10 |
Comments