coding_test/BAEKJOON

백준 4796번 C++ 풀이

CodeJin 2022. 1. 26. 01:01

https://www.acmicpc.net/problem/4796

 

4796번: 캠핑

입력은 여러 개의 테스트 케이스로 이루어져 있다. 각 테스트 케이스는 한 줄로 이루어져 있고, L, P, V를 순서대로 포함하고 있다. 모든 입력 정수는 int범위이다. 마지막 줄에는 0이 3개 주어진다.

www.acmicpc.net

시간 제한 메모리 제한 solved.ac 티어
1초 128MB 실버 5

문제

등산가 김강산은 가족들과 함께 캠핑을 떠났다. 하지만, 캠핑장에는 다음과 같은 경고문이 쓰여 있었다.

캠핑장은 연속하는 20일 중 10일동안만 사용할 수 있습니다.

강산이는 이제 막 28일 휴가를 시작했다. 이번 휴가 기간 동안 강산이는 캠핑장을 며칠동안 사용할 수 있을까?

강산이는 조금 더 일반화해서 문제를 풀려고 한다. 

캠핑장을 연속하는 P일 중, L일동안만 사용할 수 있다. 강산이는 이제 막 V일짜리 휴가를 시작했다. 강산이가 캠핑장을 최대 며칠동안 사용할 수 있을까? (1 < L < P < V)

입력

입력은 여러 개의 테스트 케이스로 이루어져 있다. 각 테스트 케이스는 한 줄로 이루어져 있고, L, P, V를 순서대로 포함하고 있다. 모든 입력 정수는 int범위이다. 마지막 줄에는 0이 3개 주어진다.

출력

각 테스트 케이스에 대해서, 강산이가 캠핑장을 최대 며칠동안 사용할 수 있는지 예제 출력처럼 출력한다.


문제를 이해하는데 조금 힘들었다. 연속하는 P일, 그러니까 2/1~2/5일과 같이 붙어있는(?) P일 중에서 연속해서 L일동안만 사용할 수 있는 캠핑장이 있는데, 이러한 조건속에서 V일동안 휴가를 갔을 때, 최대한 많이 이 캠핑장을 이용할 수 있는 일 수를 구해야 한다.

 

사실 이 문제는 정말 직관적이다. 그냥 처음부터 L일을 먼저 사용하고 P - L일은 건너뛴 후에, 다시 L일을 사용하고 P - L일을 건너뛰는 것을 반복한다. 그러다가 마지막에 V mod P (V % P)일만큼 남게 된다면, V mod P이 L일보다 크다면 L일만큼, 작다면 V mod P일만큼 사용하면 된다.

 

#include <bits/stdc++.h>
using namespace std;

int main () {
    ios_base::sync_with_stdio(false);
    cin.tie(nullptr);
    int l, p, v, result;
    int case_num = 1;

    while(true) {
        result = 0;
        cin >> l >> p >> v;
        if(!l && !p && !v) break;

        result = ((v / p) * l) + min(v % p, l);
        cout << "Case " << case_num++ << ": " << result << "\n";
    }
}