Notice
Recent Posts
Recent Comments
Link
- Today
- Total
일 | 월 | 화 | 수 | 목 | 금 | 토 |
---|---|---|---|---|---|---|
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 | 31 |
Tags
- subversion
- 서버 접근
- 백준 java jaekjoon JAVA
- jenkins
- javascript
- boj
- 자바
- 1773번
- 백준 JAVA
- rocky linux
- DBeaver
- poll scm
- PostgreSQL
- 사용법
- 백준
- ora-01476
- baekjoon
- 메뉴얼
- Rocky Linux 9
- linux
- java
- available plugins
- tomcat-users.xml
- bekjoon
- jaekjoon java
- 환경번수
- putty
- jsonb select
- 제수가 0입니다
- SVN
Archives
기록하는 개발자
[백준 4796번] 캠핑 - JAVA 알고리즘 본문
4796번 |
문제 | |
등산가 김강산은 가족들과 함께 캠핑을 떠났다. 하지만, 캠핑장에는 다음과 같은 경고문이 쓰여 있었다. 캠핑장은 연속하는 20일 중 10일동안만 사용할 수 있습니다. 강산이는 이제 막 28일 휴가를 시작했다. 이번 휴가 기간 동안 강산이는 캠핑장을 며칠동안 사용할 수 있을까? 강산이는 조금 더 일반화해서 문제를 풀려고 한다. 캠핑장을 연속하는 P일 중, L일동안만 사용할 수 있다. 강산이는 이제 막 V일짜리 휴가를 시작했다. 강산이가 캠핑장을 최대 며칠동안 사용할 수 있을까? (1 < L < P < V) |
|
입력 | |
입력은 여러 개의 테스트 케이스로 이루어져 있다. 각 테스트 케이스는 한 줄로 이루어져 있고, L, P, V를 순서대로 포함하고 있다. 모든 입력 정수는 int범위이다. 마지막 줄에는 0이 3개 주어진다. | |
출력 | |
각 테스트 케이스에 대해서, 강산이가 캠핑장을 최대 며칠동안 사용할 수 있는지 예제 출력처럼 출력한다. | |
예제 입력 | 예제 출력 |
5 8 20 5 8 17 0 0 0 |
Case 1: 14 Case 2: 11 |
import java.io.BufferedReader;
import java.io.BufferedWriter;
import java.io.IOException;
import java.io.InputStreamReader;
import java.io.OutputStreamWriter;
import java.text.ParseException;
import java.util.StringTokenizer;
public class Main {
public static void main(String[] args) throws IOException, ParseException {
// TODO Auto-generated method stub
BufferedReader br = new BufferedReader(new InputStreamReader(System.in)); // 선언
BufferedWriter bw = new BufferedWriter(new OutputStreamWriter(System.out)); // 선언
StringTokenizer st;
int L = 0; //사용 가능한 일
int P = 0; //연속하는 일
int V = 0; //휴가 기간
int i = 0; //Case번호
while(true) {
int total;
i++;
st = new StringTokenizer(br.readLine());
L = Integer.parseInt(st.nextToken());
P = Integer.parseInt(st.nextToken());
V = Integer.parseInt(st.nextToken());
if(V == 0) {
break;
}
if(V%P>L) { //휴가 기간에서 연속 가능일을 나눈 나머지 값이 사용 가능일보다 클때
total = V/P*L+L;
}else {
total = V/P*L+V%P;
}
bw.write("Case "+i+": "+total+"\n");
}
bw.close();
br.close();
}
}
개인적으로 정리한 내용을 간단하게 풀어 작성했습니다. 이해가 안가는 부분은 댓글 남겨주시면 설명해드리겠습니다. |
'Baekjoon Online Judge' 카테고리의 다른 글
[백준 1817번] 짐 챙기는 숌 - JAVA 알고리즘 (0) | 2022.07.26 |
---|---|
[백준 2839번] 설탕배달 - JAVA 알고리즘 (0) | 2022.07.12 |
[백준 2751번] 수 정렬하기2 - JAVA 알고리즘 (0) | 2022.07.01 |
[백준 1205번] 등수 구하기 - JAVA 알고리즘 (0) | 2022.06.23 |
[백준 1996번] 지뢰찾기 - JAVA 알고리즘 (0) | 2022.06.17 |
Comments