알고리즘

[백준/Java]Q1712

  • -
반응형

백준 알고리즘 8단계 기본 수학1 1712번 문제입니다.


Q. 월드전자는 노트북을 제조하고 판매하는 회사이다. 노트북 판매 대수에 상관없이 매년 A만원의 고정 비용이 들며, 한 대의 노트북을 생산하는 데에는 총 B만원의 가변 비용이 든다고 한다. 
노트북 판매 가격을 C라고 했을 때, 손익분기점(총 수입이 총 비용보다 많아지게 되는 지점)을 구하는 프로그램을 작성하시오. 

[입력]
- 첫째 줄에 A, B, C가 빈 칸을 사이에 두고 순서대로 주어진다.
- A : 고정 비용 
- B : 가변 비용 
- C : 판매 가격 

[조건]
- A, B, C는 21억 이하의 자연수이다.
- 첫 번째 줄에 손익분기점 즉 최초로 이익이 발생하는 판매량을 출력한다. 손익분기점이 존재하지 않으면 -1을 출력한다.

 

풀이

이 문제는 판매 가격이 비용보다 높아지는 경우를 구하면 되는 문제였다. 단, 가변 비용이 판매 가격보다 높은 경우는 절대 조건이 성립되지 않았다.

 

각각의 값을 변수로 봤을 때 아래와 같이 식이 세워졌다.

1. a + (b * i) < c * i
2. a/i + b < c
3. a/i < c - b
4. a < (c - b) * i

-

처음엔 여기까지 생각하고 반복문을 돌려 i를 구할 생각이었는데 시간 초과로 통과할 수 없었다.

해서 추가한 것이 아래의 식이다.


5. (170 - 70) * i = 1000
6. i = 10

여기서 i가 +1되는 순간이 손익분기점이 될 것이다.

위 알고리즘을 바탕으로 프로그램을 작성했다.

 

소스
package com.baek.algo;

import java.io.BufferedReader;
import java.io.IOException;
import java.io.InputStreamReader;
import java.util.StringTokenizer;

public class Q1712 {

	public static void main(String[] args) throws IOException {
		BufferedReader bf  = new BufferedReader(new InputStreamReader(System.in));
		StringTokenizer st = new StringTokenizer(bf.readLine(), " ");

		int a = Integer.parseInt(st.nextToken());
		int b = Integer.parseInt(st.nextToken());
		int c = Integer.parseInt(st.nextToken());
		int point = 1;

		// 가변 비용이 판매 가격보다 높거나 같다면 손익분기점이 존재하지 않음
		if(b >= c) {
			point = -1;
		} else {
			point = (a / (c - b)) + 1;
		}

		System.out.println(point);

		bf.close();
	}
}
반응형

'알고리즘' 카테고리의 다른 글

[백준/Java]Q1712  (0) 2021.07.12
[백준/Java]Q1316  (0) 2021.07.08
[백준/Java]Q1065  (0) 2021.07.08
[백준/Java]Q4344  (0) 2021.07.08
[백준/Java]Q1110  (0) 2021.07.06
Contents

포스팅 주소를 복사했습니다.

이 글이 도움이 되었다면 공감 부탁드립니다.