[백준 알고리즘 문제풀이][JAVA][1712번] 손익분기점

문제 - 백준 문제 바로가기

월드전자는 노트북을 제조하고 판매하는 회사이다.
노트북 판매 대수에 상관없이 매년 임대료, 재산세, 보험료, 급여 등 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을 출력한다.



시간제한

0.35초



알고리즘 유형

  • 수학
  • 사칙연산


예제입력 1

1000 70 170

예제출력 1

11


예제입력 2

3 2 1

예제출력 2

-1


예제입력 3

2100000000 9 10

예제출력 3

2100000001




풀이 1


import java.io.*;
import java.util.*;

public class Main {
  public static void main(String[] args) throws IOException {
    go2();
  }

  public static void go2() throws IOException {
    BufferedReader br = new BufferedReader( new InputStreamReader( System.in ) );
    BufferedWriter bw = new BufferedWriter( new OutputStreamWriter( System.out ) );
    String[] abc = br.readLine().split(" "); // A 고정비용, B 한대생산비용, C노트북가격
    int a = Integer.parseInt(abc[0]);
    int b = Integer.parseInt(abc[1]);
    int c = Integer.parseInt(abc[2]);
    int sell=b==c?-1:(a/(c-b))+1;
    bw.write((sell<1?-1:sell)+"");
    bw.flush();
    bw.close();
  }

}



풀이 2


import java.io.*;
import java.util.*;

public class Main {
  public static void main(String[] args) throws IOException {
    go();
  }

  public static void go(){
    Scanner sc = new Scanner(System.in);
    int a = sc.nextInt();   //연 고정비용
    int b = sc.nextInt();   //노트북 한대 생산비용
    int c = sc.nextInt();   //노트북 판매가격
    int res = c==b?0:(a/(c-b))+1;
    System.out.println(res<1?-1:res);
  }


}





GitHub 소스는 여기서 확인 가능 합니다.




마지막 수정