HDU 1241 Oil Deposits

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

最基本的图论问题

DFS 和BFS都能做

DFS

View Code
 1 #include <stdio.h>
 2 #include <stdlib.h>
 3 #include <string.h>
 4 #define maxn 107
 5 char map[maxn][maxn];//邻接矩阵存图
 6 int visit[maxn][maxn];//标记节点是否被访问过0表示未被访问过1表示访问过
 7 int dir[8][2] = {{0,1},{1,1},{-1,0},{0,-1},{1,0},{-1,-1},{1,-1},{-1,1}};
 8 //八个方向
 9 int m,n;
10 void dfs(int x,int y)
11 {
12     int i;
13     for (i = 0; i < 8; ++i)
14     {
15         int tx = x + dir[i][0];
16         int ty = y + dir[i][1];
17         if (map[tx][ty] == '@' && tx >= 0 && tx < m && ty >= 0 && ty < n && !visit[tx][ty])
18         {
19             visit[tx][ty] = 1;
20             dfs(tx,ty);
21         }
22     }
23 }
24 int main()
25 {
26     int i,j;
27     while (~scanf("%d%d",&m,&n))
28     {
29         if (!m && !n) break;
30         int cnt = 0;
31         memset(visit,0,sizeof(visit));
32         for (i = 0; i < m; ++i) scanf("%s",map[i]);
33         //邻接矩阵的O(n^2)找边
34         for (i = 0; i < m; ++i)
35         {
36             for (j = 0; j < n; ++j)
37             {
38                 if (map[i][j] == '@' && !visit[i][j])
39                 {
40                     visit[i][j] = 1;
41                     cnt++;
42                     dfs(i,j);
43                 }
44             }
45         }
46         printf("%d\n",cnt);
47     }
48     return 0;
49 }

BFS

View Code
 1 #include <stdio.h>
 2 #include <stdlib.h>
 3 #include <string.h>
 4 #define maxn 107
 5 struct node
 6 {
 7     int x,y;
 8 };
 9 char map[maxn][maxn];//邻接矩阵存图
10 int visit[maxn][maxn];//标记节点是否被访问过0表示未被访问过1表示访问过
11 int dir[8][2] = {{0,1},{1,1},{-1,0},{0,-1},{1,0},{-1,-1},{1,-1},{-1,1}};
12 node q[maxn*maxn];
13 //八个方向
14 int m,n,l,r;
15 void bfs()
16 {
17     int i;
18     while (l < r)
19     {
20         node pt = q[l++];//从队列中取出该节点
21         node p;
22         for (i = 0; i < 8; ++i)//寻找其八个方向
23         {
24             p.x = pt.x + dir[i][0];
25             p.y = pt.y + dir[i][1];
26             if (map[p.x][p.y] == '@' && p.x >= 0 && p.x < m
27                 && p.y >= 0 && p.y < n && !visit[p.x][p.y])//满足条件
28             {
29                visit[p.x][p.y] = 1;
30                q[r++] = p;//入队列
31             }
32         }
33     }
34 }
35 
36 int main()
37 {
38     //freopen("d.txt","r",stdin);
39     int i,j;
40     while (~scanf("%d%d",&m,&n))
41     {
42         if (!m && !n) break;
43         int cnt = 0;
44         memset(visit,0,sizeof(visit));
45         for (i = 0; i < m; ++i) scanf("%s",map[i]);
46         node p;
47         l = r  =0;
48         for (i = 0; i < m; ++i)
49         {
50             for (j = 0; j < n; ++j)
51             {
52                 if (map[i][j] == '@' && !visit[i][j])
53                 {
54                     p.x = i; p.y = j;
55                     q[r++] = p;//入队列
56                     visit[i][j] = 1;//标记为已经访问过
57                     cnt++;
58                     bfs();
59                 }
60             }
61         }
62         printf("%d\n",cnt);
63     }
64     return 0;
65 }

 

posted @ 2012-08-03 17:53  时光旅行的懒猫  阅读(185)  评论(0编辑  收藏  举报