SWEA::2105 디저트 카페


나는 백트래킹을 이용하여 풀었다.

check 배열로는 방문한 숫자를 체크하였고, visited 배열로는 방문한 지점을 체크하였다.

또한 0~4 까지의 모드값을 주고, 이를 활용하였다.


<mode에 따른 이동가능 지역>

0 : 우하

1 : 우하, 좌하

2 : 좌하, 좌상

3 : 좌상, 우상

4 : 우상


조건을 조금 더 까다롭게 주면 굳이 방문하지 않아도 되는 지점들을 걸러 낼 수 있을텐데 n값이 크지 않아 그부분 까지는 코딩하지 않았다.


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
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
#include <stdio.h>
#include <memory.h>
using namespace std;
 
int t, n, cnt, res,sx,sy;
int check[101];
int visited[21][21];
int map[22][22];
 
//현재 상태를 나타내줌
//mode = {0, 1, 2, 3, 4}
void solve(int x, int y,int mode) {
    cnt++;
    check[map[x][y]] += 1;
    visited[x][y] += 1;
 
    if (mode == 4 && visited[x][y]==2) {
        if (res < cnt-1) {
            res = cnt-1;
        }
    }
    else {
        if (mode == 0) {
            if (!check[map[x + 1][y + 1]] && map[x][y] != 0) {
                solve(x + 1, y + 11);
            }
        }
        else if (mode == 1) {
            if (!check[map[x + 1][y + 1]] && map[x + 1][y + 1!= 0) {
                solve(x + 1, y + 11);
            }
            if (!check[map[x + 1][y - 1]] && map[x + 1][y - 1!= 0) {
                solve(x + 1, y - 12);
            }
        }
        else if (mode == 2) {
            if (!check[map[x + 1][y - 1]] && map[x + 1][y - 1!= 0) {
                solve(x + 1, y - 12);
            }
            if (!check[map[x - 1][y - 1]] && map[x - 1][y - 1!= 0) {
                solve(x - 1, y - 13);
            }
        }
        else if (mode == 3) {
            if (!check[map[x - 1][y - 1]] && map[x - 1][y - 1!= 0) {
                solve(x - 1, y - 13);
            }
            if (sx == x - 1 && sy == y + 1) {
                solve(x - 1, y + 14);
            }
            else {
                if (!check[map[x - 1][y + 1]] && map[x - 1][y + 1!= 0) {
                    solve(x - 1, y + 14);
                }
            }
        }
        else {
            if (sx == x - 1 && sy == y + 1) {
                solve(x - 1, y + 14);
            }
            else {
                if (!check[map[x - 1][y + 1]] && map[x - 1][y + 1!= 0) {
                    solve(x - 1, y + 14);
                }
            }
        }
    }
 
    cnt--;
    check[map[x][y]] -= 1;
    visited[x][y] -= 1;
}
 
void init() {
    memset(map, 0sizeof(map));
    res = -1;
}
 
int main() {
    scanf("%d"&t);
    for (int tc = 1; tc <= t; tc++) {
        scanf("%d"&n);
        init();
        for (int i = 1; i <= n; i++) {
            for (int j = 1; j <= n; j++) {
                scanf("%d"&map[i][j]);
            }
        }
        
        for (int i = 1; i < n; i++) {
            for (int j = 2; j < n; j++) {
                sx = i;
                sy = j;
                solve(i, j, 0);
            }
        }
 
        printf("#%d %d\n", tc, res);
    }
}
cs


'SWEA::문제풀이' 카테고리의 다른 글

1249 보급로  (0) 2018.01.25
1953 탈주범 검거  (0) 2018.01.23
2817 부분수열의 합  (0) 2018.01.19
1494 사랑의 카운슬러  (0) 2018.01.14
1265 달란트2  (0) 2018.01.10

+ Recent posts