티스토리 뷰

728x90
반응형

문제

 

땅 위에 달팽이가 있다. 이 달팽이는 높이가 V미터인 나무 막대를 올라갈 것이다.
달팽이는 낮에 A미터 올라갈 수 있다.

하지만, 밤에 잠을 자는 동안 B미터 미끄러진다.

또, 정상에 올라간 후에는 미끄러지지 않는다.
달팽이가 나무 막대를 모두 올라가려면 며칠이 걸리는지 구하는 프로그램을 작성하시오.

 

입력

 

첫째 줄에 세 정수 A, B, V가 공백으로 구분되어서 주어진다. (1 ≤ B < A ≤ V ≤ 1,000,000,000)

 

출력

 

첫째 줄에 달팽이가 나무 막대를 모두 올라가는데 며칠이 걸리는지 출력한다.

 

풀이

 

문제 자체는 사실 생각하고 말고 할 것도 없지만 속도 제한이 빠듯하게 걸려 있다.

 

그래서 취향이 아닌 BufferedReader를 사용해 풀어보았다.

 

굳이 설명을 덧붙이자면 꼭대기에 도달하는 마지막 날엔 미끄러지지 않으니까

 

전체 높이에서 하루 동안 올라갈 수 있는 거리를 제외한 후 그전에 하루씩 올라가는 높이(올라간 높이 - 미끄러진 높이)

 

로 나눈 후 올림을 해줬다. 소수여도 어쨌건 하루를 사용해야 할 테니까.

 

이후 미끄러지지 않는 마지막 날을 위해 1을 더해주었다.

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

public class Prob2869 {

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

        int a = Integer.parseInt(st.nextToken());
        double b = Double.parseDouble(st.nextToken());
        int v = Integer.parseInt(st.nextToken());

        int x = (int) (Math.ceil((v - a) / (a - b)) + 1);

        System.out.println(x);
    }
}
반응형

'Algorithm > [Java+Python+JavaScript]BackJoon' 카테고리의 다른 글

[BackJoon]2839번  (1) 2022.12.22
[BackJoon]2775번  (2) 2022.12.21
[BackJoon]10250번  (0) 2022.12.21
[BackJoon]1193번 스트림으로 풀기  (2) 2022.12.20
[BackJoon]2292번 스트림으로 풀기  (1) 2022.12.20
[BackJoon]1712번  (0) 2022.12.20
댓글
공지사항
최근에 올라온 글
최근에 달린 댓글
Total
Today
Yesterday
링크
«   2024/06   »
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
글 보관함