https://www.acmicpc.net/problem/4796
시간 제한 | 메모리 제한 | 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";
}
}
'coding_test > BAEKJOON' 카테고리의 다른 글
백준 18917번 C++ 풀이 (0) | 2022.01.27 |
---|---|
백준 2343번 C++ 풀이 (0) | 2022.01.26 |
백준 2870번 C++ 풀이 (0) | 2022.01.25 |
백준 11819번 C++ 풀이 (0) | 2022.01.22 |
백준 5585번 C++ 풀이 (0) | 2022.01.21 |