CHashtag

[프로그래머스] [Java] 부족한 금액 계산하기 본문

알고리즘

[프로그래머스] [Java] 부족한 금액 계산하기

HyoSeong 2021. 8. 2. 12:16
반응형

안녕하세요.

오늘은 프로그래머스 코딩테스트 연습 문제인 "부족한 금액 계산하기" 을 풀어 보았습니다.

 

문제 링크


https://programmers.co.kr/learn/courses/30/lessons/82612

 

 

 

문제 풀이 방법


이용료의 총 합을 수학식으로 풀어내면 price * (1 ~ count의 합) 이였습니다.

 

저는 1 ~ count까지의 합을 구하는 로직을 반복분을 사용하지 않고 수식을 이용하여 빠르게 구했습니다.

1 ~ n = (n*(1+n)) / 2

(참고 링크: https://en.wikipedia.org/wiki/1_%2B_2_%2B_3_%2B_4_%2B_%E2%8B%AF)

 

하지만 이것으로는 부족했습니다.

 

price의 최대값은 2500, count의 최대값 또한 2500이라 두 최대값을 넣고 테스트를 진행하면 int의 최대범위를 넘어 overflow가 나는 것이였죠.

 

그래서 총 비용을 구하는 로직에서 고의로 long으로 형 변환을 일으켜 계산되는 값이 long으로 나오도록 하였습니다.

 

 

이러한 방법을 사용하여 저는 문제를 풀었고,

이번 문제는 평균 약 0.02ms 정도의 속도로 테스트를 통과하였습니다.

코드


class Solution {
    public long solution(int price, int money, int count) {
        long result = price * ((long)count * (1 + count) / 2);
        
        if(result <= money) {
            return 0;
        }
        else 
        {
            return result - (long)money;    
        }
    }
}
반응형