标签:
题目描述
输入
Output
Sample Input
6 9 ....#. .....# ...... ...... ...... ...... ...... #@...# .#..#. 11 9 .#......... .#.#######. .#.#.....#. .#.#.###.#. .#.#..@#.#. .#.#####.#. .#.......#. .#########. ........... 11 6 ..#..#..#.. ..#..#..#.. ..#..#..### ..#..#..#@. ..#..#..#.. ..#..#..#.. 7 7 ..#.#.. ..#.#.. ###.### ...@... ###.### ..#.#.. ..#.#.. 0 0
Sample Output
45 59 6 13
解题思路:
深搜的方法解决,题目意思就是从@开始找.并与@连通,碰到#等于碰到了墙,题目很简单,@可以向四个方向上、下、左、右走,所以 用四个坐标标记出来,然后,再一一遍历,递归调用寻找,用一个30*30的数组标识此点有没有走过,避免走重复
程序代码:
#include <cstdio> #include <cstring> using namespace std; int n,m,cot; char map[30][30]; int to[4][2] = {{1,0},{0,1},{-1,0},{0,-1}}; void dfs(int i,int j) { cot++; map[i][j] = ‘#‘; for(int k = 0; k<4; k++) { int x = i+to[k][0]; int y = j+to[k][1]; if(x<n && y<m && x>=0 && y>=0 && map[x][y] == ‘.‘) dfs(x,y); } return; } int main() { int i,j,fi,fj; while(~scanf("%d%d%*c",&m,&n)&&m&&n) { for(i = 0; i<n; i++) { for(j = 0; j<m; j++) { scanf("%c",&map[i][j]); if(map[i][j] == ‘@‘) { fi = i; fj = j; } } getchar(); } cot= 0; dfs(fi,fj); printf("%d\n",cot); } return 0; }
标签:
原文地址:http://www.cnblogs.com/www-cnxcy-com/p/4678523.html