본문 바로가기
Algorithm

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

by Jiseong 2021. 8. 30.

문제 설명

새로 생긴 놀이기구는 인기가 매우 많아 줄이 끊이질 않습니다. 이 놀이기구의 원래 이용료는 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는 자연수

 

 

Source

//
//  main.swift
//  Programmers_부족한_금액_계산하기
//
//  Created by 임지성 on 2021/08/30.
//

import Foundation

func solution(_ price:Int, _ money:Int, _ count:Int) -> Int64{
    var answer:Int64 = -1

    //price*count + price*(count+1) + price*(count+2) + price*(count+3) = total
    //total - money = answer
    var total = 0

    for cnt in 1...count {
        total += price * cnt
    }
    answer = Int64(total - money)

    if answer > 0 {
        return answer
    } else {
        return 0
    }
}

//고차함수
/*func solution(_ price:Int, _ money:Int, _ count:Int) -> Int64{
    let answer = (1...count).reduce(0) { $0 + price * $1 }
    return answer > money ? Int64(answer - money) : 0
}*/

print(solution(3, 30, 4))

 

프로그래머스서 하는데 뭐 자꾸 컴파일에러가 나길래.. 문법적인 것도 아닌거라 한 10분 씨름 했다.

 

냅다 띡 풀기만 하지말고, 기본 개념부터 잡자. 자료구조.. 알고리즘 이런것들

댓글