HDU 2821 Pusher

  原题链接:http://acm.hdu.edu.cn/showproblem.php?pid=2821

  首先,题目描述给的链接游戏很好玩,建议先玩几关,后面越玩越难,我索性把这道题A了,也就相当于通关了。

  其实这道题算是比较水点搜索题,直接DFS + 回溯,但是题目描述不是很清楚使得很难下手,后来枚举题意才知道在边缘位置不会出现嵌套盒子,而且所有输入都肯定有解决的方案,所有的输入数据都是标准的。

 1 #include <stdio.h>
 2 #include <string.h>
 3 #include <string>
 4 #include <stdlib.h>
 5 #include <math.h>
 6 #include <vector>
 7 #include <map>
 8 #include <queue>
 9 #include <algorithm>
10 #include <iostream>
11 #include <stack>
12 using namespace std;
13 const int maxn = 30;
14 
15 int dr[4][2] = {{1, 0}, {-1, 0}, {0, 1}, {0, -1}};
16 char dd[4] = {'R', 'L', 'D', 'U'};
17 char g[maxn][maxn];
18 char path[25 * 25 * 10];
19 int a[maxn][maxn];
20 int r, c;
21 bool ok(int x, int y)
22 {
23     if(x >= 0 && x < c && y >= 0 && y < r && a[y][x] == 0)
24         return true;
25     return false;
26 }
27  
28 int dfs(int cy, int cx, int cnt, int len)
29 {
30     if(len == cnt)
31         return 1;
32     for(int k = 0; k < 4; k++)
33     {
34         int x = cx + dr[k][0];
35         int y = cy + dr[k][1];
36         if(ok(x, y))
37         {
38             do
39             {
40                 x += dr[k][0];
41                 y += dr[k][1];
42             }
43             while(ok(x, y));
44             if(x >= 0 && x < c && y >= 0 && y < r)
45             {
46                 int tmp = a[y][x];
47                 a[y + dr[k][1]][x + dr[k][0]] += a[y][x] - 1;
48                 a[y][x] = 0;
49                 path[len] = dd[k];
50                 if(dfs(y, x, cnt, len+1))
51                     return 1;
52                 path[len] = '\0';
53                 a[y][x] = tmp;
54                 a[y + dr[k][1]][x + dr[k][0]] -= a[y][x] - 1;
55             }
56         }
57  
58     }
59     return 0;
60 }
61  
62 int main()
63 {
64     int cnt;
65     while(scanf("%d %d", &c, &r) != EOF)
66     {
67         cnt = 0;
68         for(int i = 0; i < r; i++)
69         {
70             scanf("%s", g[i]);
71             for (int j = 0; j < c; j++)
72             {
73                 if(g[i][j] != '.')
74                     cnt += g[i][j] - 'a' + 1, a[i][j] = g[i][j] - 'a' + 1;
75                 else
76                     a[i][j] = 0;
77             }
78         }
79         int i, j;
80         bool flag = false;
81         for(i = 0; i < r; i++)
82         {
83             for(j = 0; j < c; j++)
84             {
85                 if(a[i][j] == 0 && dfs(i, j, cnt, 0))
86                 {
87                     flag = true;
88                     break;
89                 }
90             }
91             if(flag) break;
92         }
93         printf("%d\n%d\n", i, j);
94         for(int i = 0; i < cnt; i++) putchar(path[i]);
95         putchar('\n');
96     }
97     return 0;
98 }
99  
View Code

 

  

posted @ 2013-07-09 11:18  芒果布丁  阅读(251)  评论(0编辑  收藏  举报