Competition/Baekjoon

[백준] 1525번 자바 퍼즐

bisi 2020. 4. 18. 11:54
문제 출처 

https://www.acmicpc.net/problem/1525

 

1525번: 퍼즐

세 줄에 걸쳐서 표에 채워져 있는 아홉 개의 수가 주어진다. 한 줄에 세 개의 수가 주어지며, 빈 칸은 0으로 나타낸다.

www.acmicpc.net

 

 

 

접근 방식 및 풀이

- BruteForce와 BFS 활용 문제

- 자세한 것은 아래 주석 참고

- 참고블로그

 

 

 

소스 코드 
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
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
import java.util.Scanner;
 
public class Main {
 
    private static int[] dx = {1-100};
    private static int[] dy = {001-1};
    private static Queue<Integer> queue;
    private static final int MAX = 10001;
    private static HashMap<Integer,Integer> map;
 
    public static void main(String[] args) {
 
        Scanner sc = new Scanner(System.in);
        int start = 0;
 
        // 입력값을 한줄의 string으로 만든다.
        for (int i = 0; i <3 ; i++) {
            for (int j = 0; j <3 ; j++) {
                int tmp = sc.nextInt();
                if(tmp ==0){
                    tmp=9;
                }
                start = start *10 +tmp;// 자리수를 한칸씩 이동하기 위해 10의배수로 처리리            }
            }
        }
 
        queue = new LinkedList<>();
        map = new HashMap<Integer, Integer>();
 
        queue.add(start);
        map.put(start, 0);
        // 처음 시작 점을 큐에 넣고 이동 시킴.
        // 193/425/786
        // 예를 들어 5를 찾아갈때 i*3+j 식을 활용하여 i가 1이고, j가 2라면 5를 찾아 갈수 있다.
        while (!queue.isEmpty()){
            // 9가 나오는 위치를 찾아서 위치를 찾고 해당 위치를 기준으로 x,y의 위치를 찾는다.
            // x,y의 위치를 찾은 뒤에 그 인데스로 9의 값을 이동시킨다.
            // 이동시키면서 9가 우측 하단으로 갈 수 있도록 계속해서 swap해준다.
 
            int nowNum = queue.remove();// 현재 위치 숫자 가져옴.
            String now = String.valueOf(nowNum);
            int nine = now.indexOf('9');// 9의 위치를 찾아서 움직일 것
            int x = nine/3;
            int y = nine%3;
 
            for (int k = 0; k <4 ; k++) {
                int nx = x + dx[k];
                int ny = y + dy[k];
                if((nx >= 0 && nx<3&& (ny >= 0 && ny<3)){
                    // 상하좌우의 범위안에서 찾는다. 서로의 값 바꿔주는 부분
                    StringBuilder next = new StringBuilder(now);
                    char temp = next.charAt(x*3 +y);
                    next.setCharAt(x*3 +y, (char) next.charAt(nx*3 +ny));
                    next.setCharAt(nx*3 +ny, temp);
                    int num = Integer.parseInt(next.toString());
 
                    if(!map.containsKey(num)){
                        //현재 가지고 있는 count에서 +1
                        map.put(num, map.get(nowNum) +1);
                        queue.add(num);
                    }
                }
            }
        }
        if(map.containsKey(123456789)){
            System.out.println(map.get(123456789));
        }else{
            System.out.println("-1");
        }
 
    }
}
 
 

 

 

결과