백준 - DSLR
문제 링크
https://www.acmicpc.net/problem/9019
문제 입출력
3
1234 3412
1000 1
1 16
LL
L
DDDD
문제 풀이
import java.io.BufferedReader;
import java.io.FileInputStream;
import java.io.InputStreamReader;
import java.util.ArrayDeque;
import java.util.Queue;
import java.util.StringTokenizer;
public class Main {
static int T, src, tgt;
static String ans;
static boolean[] visit;
static Queue<Node> q = new ArrayDeque<>();
public static void main(String[] args) throws Exception {
BufferedReader br = new BufferedReader(new InputStreamReader(System.in));
T = Integer.parseInt(br.readLine());
for (int t = 0; t < T; t++) {
StringTokenizer st = new StringTokenizer(br.readLine());
src = Integer.parseInt(st.nextToken());
tgt = Integer.parseInt(st.nextToken());
// 초기화
ans = "";
visit = new boolean[10000];
q.clear();
// 탐색
bfs();
// 출력
System.out.println(ans);
}
} // end main
private static void bfs() {
q.offer(new Node(src, ""));
visit[src] = true;
while (!q.isEmpty()) {
Node node = q.poll();
int cur = node.cur;
if (cur == tgt) {
ans = node.ans;
return;
}
int D = (cur * 2) % 10000;
if (!visit[D]) {
q.offer(new Node(D, node.ans + "D"));
visit[D] = true;
}
int S = (cur == 0) ? 9999 : cur - 1;
if (!visit[S]) {
q.offer(new Node(S, node.ans + "S"));
visit[S] = true;
}
int L = (cur % 1000) * 10 + cur / 1000;
if (!visit[L]) {
q.offer(new Node(L, node.ans + "L"));
visit[L] = true;
}
int R = (cur % 10) * 1000 + cur / 10;
if (!visit[R]) {
q.offer(new Node(R, node.ans + "R"));
visit[R] = true;
}
}
} // end bfs
static class Node {
int cur;
String ans;
public Node(int cur, String ans) {
super();
this.cur = cur;
this.ans = ans;
}
@Override
public String toString() {
return "Node [cur=" + cur + ", ans=" + ans + "]";
}
} // end Node
}
- bfs 를 이용해서 가능한 경우를 탐색합니다.
# 백준 DSLR java # 백준 DSLR bfs
728x90
'✏️ 𝗔𝗹𝗴𝗼𝗿𝗶𝘁𝗵𝗺 > 백준 알고리즘' 카테고리의 다른 글
[BJ10026] 적록색약 (0) | 2022.10.10 |
---|---|
[BJ13023] ABCDE (0) | 2022.10.02 |
[BJ2583] 영역 구하기 (0) | 2022.09.21 |
[BJ7569] 토마토 (0) | 2022.09.21 |
[BJ7576] 토마토 (0) | 2022.09.19 |