프로그래머스 코딩테스트 연습/Lv.1

[프로그래머스] 부족한 금액 계산하기 (Kotlin, 코틀린)

KwakEuiJin 2023. 2. 8. 09:49

부족한 금액 계산하기

 

문제 설명

 
새로 생긴 놀이기구는 인기가 매우 많아 줄이 끊이질 않습니다. 이 놀이기구의 원래 이용료는 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.  입력된 price를 count만큼 반복하는데 이 때 price는 각 index +1 만큼의 배수로 이루어져 있다.
  2. 그렇기에 각 인덱스에 해당하는 값을 넣어 준 후 총 비용을 구한다.
  3. 총 비용에서 현재 가지고 있는 money와의 차를 구한다 But, money가 더 클 경우를 먼저 분기하여 0으로 return시킨다.

 

정답 코드

fun solution(price: Int, money: Int, count: Int): Long {
    val sum = Array(count) { ((it + 1) * price).toLong() }.sum()
    return if (sum <= money) {
        0
    } else {
        sum - money.toLong()
    }
}

난이도 : 하(Long 타입으로 인해 최하 -> 하) 

 

헷갈렸던 부분 : 총 금액의 합을 구하는 과정에서 1 ≤ money ≤ 1,000,000,000 제한 사항 중 Int의 범위를 벗어나는 녀석이 들어올 가능성이 있다. -> 즉 합계를 구할 때 Int의 범위를 벗어나기에 Long의 형식으로 형 변환을 하여 합계를 도출해야한다.

 

 

다른사람의 풀이

-> 나도 나름 깔끔하게 푼 것 같아서 좋았다 ㅎ