BOJ 8911. 거북이
    simulation
    - 주어진 명령대로 거북이를 움직이면서 좌표의 최대, 최소를 구한다
- 시작점은 (0, 0)
- 최대, 최소의 값들의 직사각형 크기를 구한다.
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
41
42
43
44
45
46
import java.io.*;
public class Main {
	static int N;
	static int[] dx = {-1, 0, 1, 0};
	static int[] dy = { 0, 1, 0,-1};
	static int solution(char[] orders) {
		int dir = 0;
		int r = 0, c = 0;
		int maxR, maxC, minR, minC;
		maxR = maxC = minR = minC = 0;
		for (int i = 0; i < orders.length; i++) {
			char order = orders[i];
			if (order == 'L')
				dir = (dir + 3) % 4;
			else if (order == 'R')
				dir = (dir + 1) % 4;
			else if (order == 'F') {
				r += dx[dir];
				c += dy[dir];
				maxR = Math.max(maxR, r);
				minR = Math.min(minR, r);
				maxC = Math.max(maxC, c);
				minC = Math.min(minC, c);
			}
			else {
				int backDir = (dir + 2) % 4;
				r += dx[backDir];
				c += dy[backDir];
				maxR = Math.max(maxR, r);
				minR = Math.min(minR, r);
				maxC = Math.max(maxC, c);
				minC = Math.min(minC, c);
			}
		}
		return (maxR - minR) * (maxC - minC);
	}
	public static void main(String[] args) throws Exception {
		BufferedReader in = new BufferedReader(new InputStreamReader(System.in));
		N = Integer.parseInt(in.readLine());
		for (int i = 0; i < N; i++) {
			System.out.println(solution(in.readLine().toCharArray()));
		}
	}
}