标签:搜索
<pre name="code" class="cpp">#include <iostream> #include <cstring> using namespace std; char a[100][100]; int b[100][100],n,m; int x[]={0,-1,-1,-1,0,1,1,1}; int y[]={1,1,0,-1,-1,-1,0,1}; void dfs(int i,int j)//深度搜索 { int tx,ty,k; b[i][j]=0; for (k=0;k<8;++k) { tx=i+x[k]; ty=j+y[k]; if(a[tx][ty]=='@'&&tx>0&&tx<=n&&ty>0&&ty<=m&&b[tx][ty]==1) { dfs(tx,ty); } } } int queue[10000][2]; void bfs(int i,int j)//广度搜索 { int k,tx,ty,cx,cy; int head=0,tail=0; queue[tail][0]=i; queue[tail][1]=j; tail++; b[i][j]=0; while(head<tail) { cx=queue[head][0]; cy=queue[head][1]; head++; for (k=0;k<8;++k) { tx=cx+x[k]; ty=cy+y[k]; if (tx>0&&tx<=n&&ty>0&&ty<=m&&b[tx][ty]==1&&a[tx][ty]=='@') { queue[tail][0]=tx; queue[tail][1]=ty; tail++; b[tx][ty]=0; } } } } int main() { int i,j,sum; while(true) { cin >> n >> m; if (n==0&&m==0) { break; } for (i=1;i<=n;++i) { for(j=0;j<=m;++j) { b[i][j]=1; } } sum=0; for (i=1;i<=n;++i) { cin >> a[i] ; } for (i=1;i<=n;++i) { for (j=1;j<=m;++j) { if (a[i][j]=='@'&&b[i][j]==1) { sum++; /*dfs(i,j);*/ bfs(i,j); } } } cout << sum << endl; } return 0; }
某石油勘探公司正在按计划勘探地下油田资源。他们工作在一片长方形的地域中,首先将该地域划分为许多小正方形区域,然后使用探测设备分别探测每一块小正方形区域是否有油。若在一块小正方形区域中探测到有油,则标记为’@’,否则标记为’*’。如果两个相邻区域都为1,那么它们同属于一个石油带,一个石油带可能包含很多小正方形区域,而你的任务是要确定在一片长方形地域中有多少个石油带。 所谓相邻,是指两个小正方形区域上下、左右、左上右下或左下右上同为’@’。
输入数据将包含一些长方形地域数据,每个地域数据的第一行有两个正整数m和n,表示该地域为m*n个小正方形所组成,如果m为0,表示所有输入到此结束。否则,后面m(1≤m≤100)行数据,每行有n(1≤n≤100)个字符,每个字符为’@’或’*’,表示有油或无油。每个长方形地域中,’@’的个数不会超过100。
每个长方形地域,输出油带的个数,每个油带值占独立的一行。油带值不会超过100。
- 1 1
- *
- 3 5
- *@*@*
- **@**
- *@*@*
- 1 8
- @@****@*
- 5 5
- ****@
- *@**@
- *@**@
- @@@*@
- @@**@
- 0 0
- 0
- 1
- 2
- 2
标签:搜索
原文地址:http://blog.csdn.net/zsc2014030403015/article/details/43227325