본문으로 바로가기

[백준] 2980번 : 도로와 신호등

category 알고리즘/백준 2022. 2. 2. 10:18
728x90

 

문제

 

상근이는 트럭을 가지고 긴 일직선 도로를 운전하고 있다. 도로에는 신호등이 설치되어 있다. 상근이는 각 신호등에 대해서 빨간 불이 지속되는 시간과 초록 불이 지속되는 시간을 미리 구해왔다. (빨강색과 초록색 불빛은 무한히 반복된다)

상근이의 트럭이 도로에 진입했을 때, 모든 신호등의 색상은 빨간색이고, 사이클이 막 시작한 상태이다. 상근이는 1초에 1미터를 움직인다. 신호등의 색상이 빨간색인 경우에는 그 자리에서 멈추고 초록색으로 바뀔때 까지 기다린다.

상근이가 도로의 끝까지 이동하는데 걸리는 시간을 구하는 프로그램을 작성하시오. 도로의 시작은 0미터이고, 끝은 L미터인 지점이다.

 

입력

 

첫째 줄에 신호등의 개수 N과 도로의 길이 L이 주어진다. (1 ≤ N ≤ 100, 1 ≤ L ≤ 1000)

다음 N개 줄에는 각 신호등의 정보 D, R, G가 주어진다. (1 ≤ D < L, 1 ≤ R ≤ 100, 1 ≤ G ≤ 100) D는 신호등의 위치이며, R과 G는 빨간색, 초록색이 지속되는 시간이다.

신호등은 D가 증가하는 순서로 주어지며, 같은 위치에 있는 신호등이 두 개 이상 있는 경우는 없다.

 

출력

 

첫째 줄에 상근이가 도로의 끝까지 이동하는데 걸리는 시간을 출력한다.

 

 

풀이 방법

 

예제 1의 경우를 살펴보면, 처음 신호등에 가는데까지 3초, 빨간불일 때의 대기시간 2초,

두번째 신호등까지 가는데 2초, 두번째 신호등에서 목적지의 도로의 길이까지 가는데 5초 -> 12초가 걸린다.

 

먼저, 빨간불일 때의 대기시간은 3초가 5초보다 작기 때문에 이 차이만큼 더해준 연산이다.

더 자세히 살펴보면 빨간불과 파란불을 합친 사이클 안에서 빨간불의 범주보다 작았기 때문이라는 것이다.

즉, 해당 시간에서 빨간불과 파란불을 합친값을 나눴을 때 나머지가 빨간불보다 작으면 더해주는 연산이다.

 

두번째 신호등까지 가는데의 시간은 2초 (5-3), 두번째 신호등에서 목적지까지는 5초 (10-5)이다.

이는 현재의 시간에서 이전까지 도달했을 때의 시간의 차이 값이다.

 

작성 코드

 

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
32
33
34
35
36
37
38
39
40
package baekjoon.Implementation;
 
import java.io.BufferedReader;
import java.io.IOException;
import java.io.InputStreamReader;
import java.util.StringTokenizer;
 
public class BJ_2980 {
 
    public static void main(String[] args) throws IOException {
 
        BufferedReader br=new BufferedReader(new InputStreamReader(System.in));
        StringTokenizer st=new StringTokenizer(br.readLine());
 
        int N=Integer.parseInt(st.nextToken()); // 신호등의 개수
        int L=Integer.parseInt(st.nextToken()); // 도로의 길이
        int T=0int pre=0;
 
        for(int i=0;i<N;i++){
            st=new StringTokenizer(br.readLine());
            int D=Integer.parseInt(st.nextToken());
            int R=Integer.parseInt(st.nextToken());
            int G=Integer.parseInt(st.nextToken());
 
            T+=D-pre;
            pre=D;
 
            if(T%(G+R)<R){
                T+=R-T%(G+R);
            }
 
        }
 
        T+=L-pre;
        System.out.println(T);
 
    }
 
}
 
 
 

 

 

728x90

'알고리즘 > 백준' 카테고리의 다른 글

[백준] 2563번 : 색종이  (0) 2022.02.02
[백준] 1063번 : 킹  (0) 2022.02.02
[백준] 3048번 : 개미  (0) 2022.02.02
[백준] 16943번 : 숫자 재배치  (0) 2022.01.28
[백준] 8979번 : 올림픽  (0) 2022.01.26