문제
월드전자는 노트북을 제조하고 판매하는 회사이다. 노트북 판매 대수에 상관없이 매년 임대료, 재산세, 보험료, 급여 등 A만원의 고정 비용이 들며, 한 대의 노트북을 생산하는 데에는 재료비와 인건비 등 총 B만원의 가변 비용이 든다고 한다.
예를 들어 A=1,000, B=70이라고 하자. 이 경우 노트북을 한 대 생산하는 데는 총 1,070만원이 들며, 열 대 생산하는 데는 총 1,700만원이 든다.
노트북 가격이 C만원으로 책정되었다고 한다. 일반적으로 생산 대수를 늘려 가다 보면 어느 순간 총 수입(판매비용)이 총 비용(=고정비용+가변비용)보다 많아지게 된다. 최초로 총 수입이 총 비용보다 많아져 이익이 발생하는 지점을 손익분기점(BREAK-EVEN POINT)이라고 한다.
A, B, C가 주어졌을 때, 손익분기점을 구하는 프로그램을 작성하시오.
첫째 줄에 A, B, C가 빈 칸을 사이에 두고 순서대로 주어진다. A, B, C는 21억 이하의 자연수이다.
첫 번째 줄에 손익분기점 즉 최초로 이익이 발생하는 판매량을 출력한다. 손익분기점이 존재하지 않으면 -1을 출력한다.
문제풀이
얼핏보면 손익분기점을 계산하는 문제로 보일 수 있다. 하지만 여기서 함정이 있다. A,B,C는 21억 이하의 자연수라고 했으므로 만약 "2100000000 2099999998 2099999999" 이와 같은 값이 들어오면 21억번을 연산을 해야한다. 따라서 시간초과가 발생한다.
이런 현상이 발생하지 않으려면 좀 더 우아한 방식의 코드가 필요하다. 바로 나눗셈을 이용하는 것이다. 손익분기점의 공식은 (C-B)*n - A이고 이 값이 0보다 커질 때의 n값을 출력해야한다. 그렇다면 A를 (C-B)로 나누면 n값을 구할 수 있지 않을까?
실제로 정답 n = A/(C-B)+1 이다. 1을 더하는 이유는 1번을 덜 세기 때문이다. 그렇지만 모든 경우에 이와 같은 방법이 성립하는 것은 아니다. 만약 B가 C보다 크거나 같다면 손익분기점을 찾지못한다. 계속 나눠봐야 음수값만 나오기 때문이다. 따라서 B >= C일 때를 제외했을 때의 n값을 출력해주는 코드를 작성하면 된다.
소스코드
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
|
import java.io.*;
import java.util.StringTokenizer;
public class Main {
public static void main(String args[]) throws IOException {
BufferedReader br = new BufferedReader(new InputStreamReader(System.in));
BufferedWriter bw = new BufferedWriter(new OutputStreamWriter(System.out));
StringTokenizer st = new StringTokenizer(br.readLine());
long A = Integer.parseInt(st.nextToken());
long B = Integer.parseInt(st.nextToken());
long C = Integer.parseInt(st.nextToken());
if (B >= C) bw.write(-1+"\n");
else bw.write(A/(C-B)+1+"\n");
bw.flush();
bw.close();
}
}
|
cs |
나도 이 문제에 낚여서 1시간이나 헤매다가 반례와 정답을 보고나서야 알았다 ㅠ.ㅠ...
'백준 온라인 저지 문제풀이 > JAVA' 카테고리의 다른 글
[baekjoon 2292번] 수학 1 - 벌집 (0) | 2020.12.04 |
---|---|
[baekjoon 2839번] 수학1 - 설탕배달 (0) | 2020.12.04 |
[baekjoon 1316번] 문자열 - 그룹 단어 체커 (0) | 2020.12.02 |
[baekjoon 2941번] 문자열 - 크로아티아 알파벳 (0) | 2020.12.02 |
[baekjoon 5622번] 문자열 - 다이얼 (0) | 2020.12.02 |