문제 요구사항
새로 생긴 놀이기구는 인기가 매우 많아 줄이 끊이질 않습니다. 이 놀이기구의 원래 이용료는 price원 인데, 놀이기구를 N 번 째 이용한다면 원래 이용료의 N배를 받기로 하였습니다. 즉, 처음 이용료가 100이었다면 2번째에는 200, 3번째에는 300으로 요금이 인상됩니다.
놀이기구를 count번 타게 되면 현재 자신이 가지고 있는 금액에서 얼마가 모자라는지를 return 하도록 solution 함수를 완성하세요.
단, 금액이 부족하지 않으면 0을 return 하세요.
제한사항
- 놀이기구의 이용료 price : 1 ≤ price ≤ 2,500, price는 자연수
- 처음 가지고 있던 금액 money : 1 ≤ money ≤ 1,000,000,000, money는 자연수
- 놀이기구의 이용 횟수 count : 1 ≤ count ≤ 2,500, count는 자연수
풀이
class Solution {
public long solution(int price, int money, int count) {
long answer = 0;
//등차수열의 합
long debt = (long)price * count * (count+1) / 2 - (long)money; //오버플로우 주의
if(debt < 0) return answer;
answer = debt;
return answer;
}
}
모범답안
//1
class Solution {
public long solution(long price, long money, long count) {
return Math.max(price * (count * (count + 1) / 2) - money, 0);
}
}
//2
class Solution {
public long solution(int price, int money, int count) {
long answer = money;
for (int cnt = 0; cnt < count; ++cnt) {
answer -= (price * (cnt + 1));
}
return (answer > 0 ? 0 : -answer);
}
}
//3
class Solution {
public long solution(int price, int money, int count) {
long answer = -1;
answer = (long)price*count*(count+1)/2 - money;
return answer<=0?0:answer;
}
}
실패 요인
계산 파트에서 오버플로우 처리를 하지 않아 처음에 오답이 나왔다.
잘한 점
등차수열의 합 공식을 활용해 식을 단순화하였다.
인사이트
오버플로우 처리를 위해 long 캐스팅을 어디에 해야 하는지, 알맞게 했는지 생각해보자.
Github 링크
https://github.com/ginsengcandy/Coding-Test-Practice/commit/3b08f4017105b02079eaea4a8687cd492efed7dd
[level 1] Title: 부족한 금액 계산하기, Time: 0.09 ms, Memory: 81.9 MB -Baekjoo… · ginsengcandy/Coding-Test-Practice@
…nHub
github.com
문제 출처
https://school.programmers.co.kr/learn/courses/30/lessons/82612
프로그래머스
SW개발자를 위한 평가, 교육의 Total Solution을 제공하는 개발자 성장을 위한 베이스캠프
programmers.co.kr
'Algorithm' 카테고리의 다른 글
| [알고리즘] 행렬의 덧셈 (0) | 2026.02.03 |
|---|---|
| [알고리즘] 문자열 다루기 기본 - 문자열의 길이와 구성 검증하기 (0) | 2026.02.02 |
| [알고리즘] 문자열 내림차순으로 배치하기 (0) | 2026.01.29 |
| [알고리즘] 약수의 개수와 덧셈 (0) | 2026.01.29 |
| [알고리즘] 내적 구하기 (0) | 2026.01.28 |