💎 백준/🎇 C언어

[C언어] 백준 2869번 달팽이는 올라가고 싶다

mildliner 2024. 2. 13. 21:42

달팽이는 올라가고 싶다

문제

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

달팽이는 낮에 A미터 올라갈 수 있다.

하지만, 밤에 잠을 자는 동안 B미터 미끄러진다. 또, 정상에 올라간 후에는 미끄러지지 않는다.

달팽이가 나무 막대를 모두 올라가려면, 며칠이 걸리는지 구하는 프로그램을 작성하시오.

입력

 

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

 
출력

 

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

예제 입력 1
2 1 5

 

예제 출력 1
4
예제 입력 2
5 1 6

 

예제 출력 2
2
예제 입력 3
100 99 1000000000

 

예제 출력 3
999999901
제출 코드
#include <stdio.h>

int main() {
    int up, down, tree, day;

    scanf("%d %d %d", &up, &down, &tree);

    // 마지막 날을 제외한 거리에서 하루에 올라가는 순수 거리(up-down)로 나누어 몇 일이 걸리는지 계산
    // 마지막 날에는 down을 고려하지 않으므로, tree-up을 계산의 기준으로 함
    day = (tree - up) / (up - down);

    // 나머지가 있을 경우 하루가 더 필요
    if ((tree - up) % (up - down) > 0) {
        day++;
    }

    // 마지막 날 추가
    day++;

    printf("%d", day);
}