[문제]
새로 생긴 놀이기구는 인기가 매우 많아 줄이 끊이질 않습니다. 이 놀이기구의 원래 이용료는 price원 인데, 놀이기구를 N 번 째 이용한다면 원래 이용료의 N배를 받기로 하였습니다. 즉, 처음 이용료가 100이었다면 2번째에는 200, 3번째에는 300으로 요금이 인상됩니다.
놀이기구를 count번 타게 되면 현재 자신이 가지고 있는 금액에서 얼마가 모자라는지를 return 하도록 solution 함수를 완성하세요.
단, 금액이 부족하지 않으면 0을 return 하세요.
[풀이]이 문제도 규칙을 잘 찾으면 효율적으로 풀 수 있는 문제다. n번 탄다고 했을 때
100 + 200 + 300 ...
(100 * 1) + (100 * 2) + (100 * 3) ... + (100 * n)
100 * (1 + 2 + 3 ... + n)
고로 100 * n(n+1)/2 이 되어버린다.
이를 이용해서 문제를 풀어보자. O(1)로 풀 수 있는 문제다.
def solution(price, money, count):
return max(price * count * (count+1) / 2 - money, 0)
해당 문제가 어떤 식으로 계산되어지는지 나열해보고 거기서 규칙을 찾으려고 한다면 좀 더 발견하기 쉬울 것이다.
'코딩 테스트 > Python' 카테고리의 다른 글
최대공약수와 최소공배수 (0) | 2024.12.15 |
---|---|
행렬의 덧셈 (0) | 2024.12.15 |
약수의 개수와 덧셈 (0) | 2024.12.15 |
음양 더하기 (0) | 2024.12.15 |
두 정수 사이의 합 (0) | 2024.12.15 |