반응형
01-27 05:03
- Today
- Total
Link
개발하는 고라니
[백준] 1525번 : 퍼즐 본문
반응형
[BFS]
거의 브루트 포스 문제랄까.. 가능한 모든 경우의 수를 다 돌아보는 것 같다. 나는 Set과 문자열을 이용했다. 예를 들어,
1 | 2 | 3 |
5 | 6 | 7 |
8 | 4 | 0 |
이라는 배열이 주어진다면, String str = "123567840"; 이런식으로 문자열로 변환해 Set에 넣어 값이 중복되지 않게 (이미 방문했던 배열을 피하기 위해) 하였다. 결국 Set은 "123456780" 이라는 문자열을 넣게 될 수도, 넣지 않게 될 수도 있는데, 넣지 않게 되는 경우 '-1'을 출력하면 된다.
코딩 기술이 부족하다보니, 잡기술을 여러가지 사용한 것 같다. 테크닉이 높아지면 다시 풀어 코드를 줄일 의향이 있는 문제이다.
* class Item
static class Item{
String str;
int move, y, x;
public Item(String s, int m, int yy, int xx){
str=s;
move=m;
y=yy;
x=xx;
}
}
* copyArr()
static int[][] copyArr(int[][] src){
int[][] result = new int[3][3];
for(int i=0; i<3; i++)
for(int j=0; j<3; j++)
result[i][j] = src[i][j];
return result;
}
* strToArr()
static int[][] strToArr(String str){
int[][] arr = new int[3][3];
for(int i=0; i<3; i++)
for(int j=0; j<3; j++)
arr[i][j] = str.charAt(j + (i * 3)) - '0';
return arr;
}
# Code </>
import java.io.BufferedReader;
import java.io.IOException;
import java.io.InputStreamReader;
import java.util.*;
public class Main {
static class Item{
String str;
int move, y, x;
public Item(String s, int m, int yy, int xx){
str=s;
move=m;
y=yy;
x=xx;
}
}
static int[][] strToArr(String str){
int[][] arr = new int[3][3];
for(int i=0; i<3; i++)
for(int j=0; j<3; j++)
arr[i][j] = str.charAt(j + (i * 3)) - '0';
return arr;
}
static int[][] copyArr(int[][] src){
int[][] result = new int[3][3];
for(int i=0; i<3; i++)
for(int j=0; j<3; j++)
result[i][j] = src[i][j];
return result;
}
static int[] Y = {-1, 1, 0, 0}, X = {0, 0, -1, 1};
static int result = -1;
static void BFS(String s, int yy, int xx){
Set<String> set = new HashSet<>();
Queue<Item> Q = new LinkedList<>();
set.add(s);
Q.add(new Item(s, 0, yy, xx));
while(!Q.isEmpty()){
Item item = Q.poll();
String current = item.str;
//String -> Array
int[][] curArr = strToArr(current);
int y = item.y;
int x = item.x;
int move = item.move;
for(int a=0; a<4; a++){
int ny = y+Y[a];
int nx = x+X[a];
if(ny < 0 || nx < 0 || ny > 2 || nx > 2) continue;
//copy Array
int[][] arr = copyArr(curArr);
//swap
int tmp = arr[ny][nx];
arr[ny][nx] = arr[y][x];
arr[y][x] = tmp;
//Array -> String
StringBuilder next = new StringBuilder();
for(int i=0; i<3; i++)
for(int j=0; j<3; j++)
next.append(arr[i][j]);
if(set.add(next.toString())) {
if(set.contains("123456780")){
result = move + 1;
return;
}
Q.add(new Item(next.toString(), move + 1, ny, nx));
}
}
}
}
public static void main(String[] args) throws IOException {
BufferedReader br = new BufferedReader(new InputStreamReader(System.in));
String str = "";
int y=0, x=0;
for(int i=0; i<3; i++){
StringTokenizer st = new StringTokenizer(br.readLine());
for(int j=0; j<3; j++) {
String s = st.nextToken();
str += s;
if(s.equals("0")){
y=i; x=j;
}
}
}
if(str.equals("123456780"))
System.out.println(0);
else{
BFS(str, y, x);
System.out.println(result);
}
}
}
반응형
'Programming > 백준' 카테고리의 다른 글
[백준] 16946번 : 벽 부수고 이동하기 4 (0) | 2021.03.10 |
---|---|
[백준] 9328번 : 열쇠 (0) | 2021.03.09 |
[백준] 14938번 : 서강그라운드 (0) | 2021.03.06 |
[백준] 1944번 : 복제 로봇 (0) | 2021.03.06 |
[백준] 1507번 : 궁금한 민호 (0) | 2021.03.06 |
Comments