반응형
01-27 20:45
- Today
- Total
Link
개발하는 고라니
[백준] 9019번 : DSLR 본문
반응형
[BFS]
4가지의 함수를 구현하기만 하면 간단한 BFS이다. 이 문제의 핵심은 L()과 R()에서 얼마나 시간을 단축하느냐에 달린 것 같다. L, R 함수는 언뜻보면 간단하지만, 항상 4자리임을 가정하고 하는 것이라, 4자리 이하일 때 "0"을 채워 4자리를 만들어줘야한다. 이 과정이 노련한 사람에게는 짧고 간편한 코드로 작성할 수 있겠으나... 나같은 초심자에게는 잡기술을 동원해서 겨우 AC를 받아내었다.
static int L(int x){
StringBuilder str = new StringBuilder(Integer.toString(x));
if(x < 1000) { //4자리 이하일 때
StringBuilder tmp = new StringBuilder();
for (int i = 0; i < 4 - str.length(); i++)
tmp.append(0); //부족한 자리수만큼 0붙이기
tmp.append(x); //기존 x 붙이기
str = tmp; //str에 복사
}
char zero = str.toString().charAt(0); //첫째자리 수 떼어놓기
StringBuilder sb = new StringBuilder();
sb.append(str.toString(), 1, 4).append(zero); //2, 3, 4번째 자리수붙이고, zero 붙이기
return Integer.parseInt(sb.toString());
}
static int R(int x){
StringBuilder str = new StringBuilder(Integer.toString(x));
if(x < 1000) {
StringBuilder tmp = new StringBuilder();
for (int i = 0; i < 4 - str.length(); i++)
tmp.append(0);
tmp.append(x);
str = tmp;
}
char four = str.toString().charAt(3); //마지막 자리 수 떼어놓기
StringBuilder sb = new StringBuilder();
sb.append(four).append(str.toString(), 0, 3); //four 붙이고, 나머지 붙이기
return Integer.parseInt(sb.toString());
}
# Code </>
import java.io.BufferedReader;
import java.io.IOException;
import java.io.InputStreamReader;
import java.util.LinkedList;
import java.util.Queue;
import java.util.StringTokenizer;
public class Main {
static class Node{
int v;
String command;
public Node(int vv, String c){
v=vv; command=c;
}
}
static int D(int x){
return (2 * x) % 10000;
}
static int S(int x){
return (x == 0)? 9999 : x - 1;
}
static int L(int x){
StringBuilder str = new StringBuilder(Integer.toString(x));
if(x < 1000) {
StringBuilder tmp = new StringBuilder();
for (int i = 0; i < 4 - str.length(); i++)
tmp.append(0);
tmp.append(x);
str = tmp;
}
char zero = str.toString().charAt(0);
StringBuilder sb = new StringBuilder();
sb.append(str.toString(), 1, 4).append(zero);
return Integer.parseInt(sb.toString());
}
static int R(int x){
StringBuilder str = new StringBuilder(Integer.toString(x));
if(x < 1000) {
StringBuilder tmp = new StringBuilder();
for (int i = 0; i < 4 - str.length(); i++)
tmp.append(0);
tmp.append(x);
str = tmp;
}
char four = str.toString().charAt(3);
StringBuilder sb = new StringBuilder();
sb.append(four).append(str.toString(), 0, 3);
return Integer.parseInt(sb.toString());
}
static boolean[] visit;
static void BFS(int start, int end){
Queue<Node> Q = new LinkedList<>();
visit[start] = true;
Q.add(new Node(start, ""));
while(!Q.isEmpty()){
Node n = Q.poll();
int c = n.v;
String command = n.command;
if(c == end) {
System.out.println(command);
break;
}
int d = D(c);
int s = S(c);
int l = L(c);
int r = R(c);
if(d > -1 && d < 10000 && !visit[d]){
visit[d] = true;
Q.add(new Node(d, command + "D"));
}
if(s > -1 && s < 10000 && !visit[s]){
visit[s] = true;
Q.add(new Node(s, command + "S"));
}
if(l > -1 && l < 10000 && !visit[l]){
visit[l] = true;
Q.add(new Node(l, command + "L"));
}
if(r > -1 && r < 10000 && !visit[r]){
visit[r] = true;
Q.add(new Node(r, command + "R"));
}
}
}
public static void main(String[] args) throws IOException {
BufferedReader br = new BufferedReader(new InputStreamReader(System.in));
int k = Integer.parseInt(br.readLine());
for(int i=0; i<k; i++){
StringTokenizer st = new StringTokenizer(br.readLine());
int A = Integer.parseInt(st.nextToken());
int B = Integer.parseInt(st.nextToken());
visit = new boolean[10001];
BFS(A, B);
}
}
}
반응형
'Programming > 백준' 카테고리의 다른 글
[백준] 2617번 : 구슬 찾기 (0) | 2021.03.14 |
---|---|
[백준] 1058번 : 친구 (0) | 2021.03.14 |
[백준] 10816번 : 숫자 카드 2 (0) | 2021.03.13 |
[백준] 1654번 : 랜선 자르기 (0) | 2021.03.13 |
[백준] 10815번 : 숫자 카드 (0) | 2021.03.12 |
Comments