문제 설명
새로 생긴 놀이기구는 인기가 매우 많아 줄이 끊이질 않습니다. 이 놀이기구의 원래 이용료는 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는 자연수
입출력 예 #1
이용금액이 3인 놀이기구를 4번 타고 싶은 고객이 현재 가진 금액이 20이라면, 총 필요한 놀이기구의 이용 금액은
30 (= 3+6+9+12) 이 되어 10만큼 부족하므로 10을 return 합니다.
Step1. 문제분석
문제가 길어서 그렇지 막상 단순한 계산 문제이다.
price 가격에 count를 횟수만큼 곱해서 값에 넣어준 뒤
현재 money의 값에서 빼고 그 값이 음수라면 양수로만 바꿔주면 되고
양수라면 그냥 0을 리턴하면 된다.( 0일 경우에도 0을 리턴)
Step2. 문제풀이 코드
class Solution {
public long solution(long price, long money, long count) {
long result = 0;
for(int i =1; i < count+1; i++){
money -= price*i;
}
if(money < 0){
result = money * -1;
return result;
}else{
return 0;
}
}
}
Step3. 다른 사람의 풀이 코드
class Solution {
public long solution(long price, long money, long count) {
return Math.max(price * (count * (count + 1) / 2) - money, 0);
}
}
max메소드를 사용하여 굳이 0과 비교하는 조건문을 없앴고
등차수열의 합을 이용해 하였다.
참 등차수열의 합까지 왜 연관이 안지어질까...
이전에도 다음에 이런문제 나오면 등차수열의 합 공식을 이용해서 해결해 봐야겠다고 생각했는데
막상 문제가 들이 닥치면 if, else, for문 등 내가 아는 코드로 해결하려고만 하는것 같다.
조금 다양한 시선으로 볼 필요가 있겠다.
'Java > 알고리즘' 카테고리의 다른 글
[프로그래머스/알고리즘] 내적 (자바/Java) (0) | 2022.11.19 |
---|---|
[프로그래머스/알고리즘] 나누어 떨어지는 숫자 배열 (자바/Java) (0) | 2022.11.19 |
[프로그래머스/알고리즘] x만큼 간격이 있는 n개의 숫자(자바/Java) (0) | 2022.11.19 |
[프로그래머스/알고리즘] 행렬의 덧셈 (자바/Java) (0) | 2022.11.19 |
[프로그래머스/알고리즘] 핸드폰 번호 가리기 (자바/Java) (0) | 2022.11.18 |
댓글