https://www.acmicpc.net/problem/2991
문제
창영 마을의 우체부, 우유배달원, 신문배달원은 상근이네 집에 가는 것을 매우 싫어한다. 그 이유는 상근이네 집에는 사나운 개 두 마리가 지키고 있기 때문이다. 하지만, 그들은 이 개의 행동이 예측 가능하다는 것을 모르고 있다.
매일 아침, 개 한마리는 A분동안 공격적이고, B분동안 조용히 쉬고 있다. 또다른 개는 C분동안 공격적이고, D분동안 조용히 쉰다. 두 개는 이 행동을 계속해서 연속적으로 반복한다.
우체부, 신문배달원, 우유배달원의 도착 시간이 주어졌을 때, 개 몇 마리에게 공격을 받는지 알아내는 프로그램을 작성하시오.
입력
첫째 줄에 A, B, C, D가 주어진다.
둘째 줄에는 P, M, N가 주어진다. P는 우체부의 도착 시간, M은 우유배달원의 도착 시간, N은 신문배달원의 도착 시간이다. 매일 아침이 시작하는 시간을 0이라고 한다. 도착 시간은 아침이 시작한 후 지난 시간이다. 예를 들어, P가 3이면, 우체부는 아침이 시작하고 세 번째 분이 진행되는 중에 도착했다는 뜻이다.
모든 수는 1보다 크거나 같고, 999보다 작거나 같은 정수이다.
출력
첫째 줄에는 우체부, 둘째 줄에는 우유배달원, 셋째 줄에는 신문배달원이 개 몇 마리에게 공격 받는지 출력한다.
예제 입력 1 복사
2 2 3 3
1 3 4
예제 출력 1 복사
2
1
0
예제 입력 2 복사
2 3 4 5
4 9 5
예제 출력 2 복사
1
0
0
풀이 : 나머지를 이용하여 풀 수 있는 문제
개가 [공격적인 시간 + 그렇지 않은 시간]이 한 세트이며
사람의 도착 시간에서 세트로 묶인 시간의 나머지를 구한다.
만약 그 나머지가 개의 공격적인 시간에 비해 작거나 같다면 개에게 공격받았다고 할 수 있다.
package beakjoon.bronze3;
import java.io.BufferedReader;
import java.io.IOException;
import java.io.InputStreamReader;
import java.util.StringTokenizer;
public class Beakjoon2991 {
// 백준 2991. 사나운 개
public static void main(String[] args) throws IOException {
BufferedReader br = new BufferedReader(new InputStreamReader(System.in));
StringTokenizer st = new StringTokenizer(br.readLine());
// 1번 개
int a = Integer.parseInt(st.nextToken());
int b = Integer.parseInt(st.nextToken());
// 2번 개
int c = Integer.parseInt(st.nextToken());
int d = Integer.parseInt(st.nextToken());
st = new StringTokenizer(br.readLine());
for(int i=0; i<3; i++) {
int cnt = 0; // cnt 초기화
int man = Integer.parseInt(st.nextToken());
int dog1 = man % (a+b);
int dog2 = man % (c+d);
if(dog1<=a && dog1!=0) cnt++;
if(dog2<=c && dog2!=0) cnt++;
System.out.println(cnt);
}
}
}
'알고리즘 문제풀이 > Beakjoon' 카테고리의 다른 글
[백준] 별 찍기 모음 (JAVA) (0) | 2023.02.01 |
---|---|
백준 2547. 사탕 선생 고창영 (JAVA) (0) | 2023.02.01 |
[코테/알고리즘] 백준 단계별 학습 방법 (+초보자 추천) (0) | 2022.10.25 |
[자바 알고리즘] String - 단어 뒤집기 : 주어진 N개의 단어를 뒤집어 출력하기 (0) | 2022.01.24 |
[자바 알고리즘] String - 문장 속 단어 : 문장 속에서 가장 긴 단어를 출력하기 (0) | 2022.01.24 |