티스토리 뷰
문제
창영이는 노래 여러 개를 이어서 부르는 가수이다. 유명한 노래의 비슷한 멜로디를 이어서 부르면서 언제 곡이 넘어갔는지 모르게 만드는 것이 창영이 노래의 특징이다. 이런 노래로 상업적으로 엄청난 성공을 거둔 창영이에게 큰 시련이 찾아왔다. 그것은 바로 저작권이었다.
창영이의 노래에 포함되어 있는 멜로디는 모두 저작권이 다른 사람에게 있는 노래이다. 따라서, 이 음악으로 상업적인 활동을 했기 때문에, 저작권 협회에 저작권료를 내야한다.
창영이는 자신의 앨범에 포함되어있는 저작권이 있는 멜로디의 평균값을 구해보기로 했다. 이 값은 아래와 같이 구할 수 있다.
(창영이 앨범에 수록된 곡에 포함되어 있는 저작권이 있는 멜로디의 개수) / (앨범에 수록된 곡의 개수)
이때, 평균값은 항상 올림을 해서 정수로 만들어야 한다. 예를 들어, 창영이의 1집 앨범 "영창에서 영원히 영창피아노를 친다"에 총 38개 곡이 수록되어 있고, 이 앨범에 저작권이 있는 멜로디가 894개가 있다면, 평균값은 23.53이 되고 올림해서 24가 된다.
매니저 강산이는 얼마나 많은 사람에게 저작권료를 주어야 하는지 궁금해졌다. 강산이가 알고 있는 정보는 앨범에 수록되어 있는 곡의 개수와 위에서 구한 평균값이다. 이때, 적어도 몇 곡이 저작권이 있는 멜로디인지 구하는 프로그램을 작성하시오.
입력
첫째 줄에 앨범에 수록된 곡의 개수 A와 평균값 I가 주어진다. (1 ≤ A, I ≤ 100)
출력
첫째 줄에 적어도 몇 곡이 저작권이 있는 멜로디인지 출력한다.
예제
예제 입력 1 | 예제 출력 1 |
38 24 | 875 |
예제 입력 2 | 예제 출력 2 |
1 100 | 100 |
예제 입력 3 | 예제 출력 3 |
10 10 | 91 |
풀이
우선 평균을 구하는 법을 살펴보면 (앨범 내에 저작권이 있는 멜로디의 개수) / (앨범에 수록된 곡의 개수)이므로 저작권이 있는 멜로디의 개수는 (앨범에 수록된 곡의 개수) * 평균이다. 하지만 평균값을 항상 올림하므로 이렇게 계산한 값은 저작권이 있는 멜로디의 최대 개수가 된다. 따라서 저작권 멜로디의 최소 개수는 (곡의 개수) * (평균에서 1을 뺀 수)를 계산한 다음 1을 더해주면 된다. 멜로디의 개수가 1만 증가해도 값을 올림하게 되면 평균이 1 증가해 조건에 해당하기 때문이다.
import java.io.BufferedReader
import java.io.InputStreamReader
import java.util.*
fun main() {
val br = BufferedReader(InputStreamReader(System.`in`))
val bw = System.out.bufferedWriter()
val st = StringTokenizer(br.readLine())
val count = st.nextToken().toInt()
val avg = st.nextToken().toInt()
bw.write("${count*(avg-1)+1}\n")
bw.flush()
bw.close()
br.close()
}
'Develop > Algorithm' 카테고리의 다른 글
[프로그래머스/Java] 연습문제 - 평균 구하기 (0) | 2021.08.18 |
---|---|
[프로그래머스/Java,Kotlin] 연습문제 - 문자열을 정수로 바꾸기 (0) | 2021.08.16 |
[프로그래머스/Java] 정렬 - 가장 큰 수 (0) | 2021.08.11 |
[프로그래머스/Java] 위클리 챌린지 - 1주차 - 부족한 금액 계산하기 (0) | 2021.08.10 |
[프로그래머스/Kotlin] 2019 카카오 개발자 겨울 인턴십 - 징검다리 건너기 (0) | 2021.08.06 |
- Total
- Today
- Yesterday
- 라이브 데이터
- java
- 우선순위큐
- heap
- 코틀린
- MutableLiveData
- SCPC2021
- 힙
- 아키텍처 패턴
- architectural pattern
- 후기
- 뷰모델
- hilt
- livedata
- 프로그래머스
- 자바
- 백준
- 알고리즘
- Android
- BAEKJOON ONLINE JUDGE
- gradle
- Naver AI Burning Day
- 변수
- androidx.core
- viewmodel
- 안드로이드
- error
- Kotlin
- programmers
- Algorithm
일 | 월 | 화 | 수 | 목 | 금 | 토 |
---|---|---|---|---|---|---|
1 | 2 | 3 | 4 | |||
5 | 6 | 7 | 8 | 9 | 10 | 11 |
12 | 13 | 14 | 15 | 16 | 17 | 18 |
19 | 20 | 21 | 22 | 23 | 24 | 25 |
26 | 27 | 28 | 29 | 30 | 31 |