으하하 공부일기
[SWEA] - 1940. 가랏! RC카! (D2) 본문
[문제]
RC (Radio Control) 카의 이동거리를 계산하려고 한다.
입력으로 매 초마다 아래와 같은 command 가 정수로 주어진다.
0 : 현재 속도 유지.
1 : 가속
2 : 감속
위 command 중, 가속(1) 또는 감속(2) 의 경우 가속도의 값이 추가로 주어진다.
가속도의 단위는, m/s2 이며, 모두 양의 정수로 주어진다.
입력으로 주어진 N 개의 command 를 모두 수행했을 때, N 초 동안 이동한 거리를 계산하는 프로그램을 작성하라.
RC 카의 초기 속도는 0 m/s 이다.
[예제]
아래 예제 입력에서 정답은 3 이 된다.
입력 시간 RC 카의 속도 RC 카의 이동거리
1 2 1 sec 2 m/s 2 m
2 1 2 sec 1 m/s 3 m
[제약사항]
1. N은 2이상 30이하의 정수이다. (2 ≤ N ≤ 30)
2. 가속도의 값은 1 m/s2 혹은 2 m/s2 이다.
3. 현재 속도보다 감속할 속도가 더 클 경우, 속도는 0 m/s 가 된다.
[입력]
입력은 첫 줄에 총 테스트 케이스의 개수 T, 다음 줄부터 각 테스트 케이스가 주어진다.
테스트 케이스 첫 줄에는 Command 의 수 N이 주어지고, 둘째 줄부터, 매 줄마다 각각의 Command가 주어진다.
[출력]
테스트 케이스 t에 대한 결과는 “#t”을 찍고, 한 칸 띄고, 정답을 출력한다.
(t는 테스트 케이스의 번호를 의미하며 1부터 시작한다.)
문제 풀기
1940. 가랏! RC카!
[풀이]
- 속도(v) 변수에 입력받은 command 가 1 이면 +1을, 2이면 -1을 하는데, 속도가 0보다 작아지면 0으로 저장
- 계산된 속도를 거리(d) 변수에 더해가며 저장
import java.util.Scanner;
class Solution {
public static void main(String[] args) throws Exception {
Scanner sc = new Scanner(System.in);
int t = sc.nextInt();
for(int i=1; i<=t; i++) {
int n = sc.nextInt();
int s = 0;
int d = 0;
for(int j=0; j<n; j++) {
int command = sc.nextInt();
if(command == 1) s += sc.nextInt();
else if(command == 2) s -= sc.nextInt();
if(s<0) s=0;
d += s;
}
System.out.format("#%d %d\n", i, d);
}
}
}
'SWEA > D2' 카테고리의 다른 글
[SWEA] - 1946. 간단한 압축 풀기 (D2) (0) | 2022.04.20 |
---|---|
[SWEA] - 1945. 간단한 소인수분해 (D2) (0) | 2022.04.20 |
[SWEA] - 1928. Base64 Decoder (D2) (0) | 2022.04.20 |
[SWEA] - 1926. 간단한 369게임 (D2) (0) | 2022.04.20 |
[SWEA] - 1859. 백만 장자 프로젝트 (D2) (0) | 2022.04.20 |