hdu-1241-Oil Deposits
2014-05-03 10:57
288 查看
#include<stdio.h>
#include<string.h>
char a[102][102];
int m,n,b[102][102];
void dfs(int x,int y)
{
if(!b[x+1][y]&&a[x+1][y]=='@'&&x+1<m)
{
b[x+1][y]=1;
dfs(x+1,y);
}
if(!b[x-1][y]&&a[x-1][y]=='@'&&x-1>=0)
{
b[x-1][y]=1;
dfs(x-1,y);
}
if(!b[x][y+1]&&a[x][y+1]=='@'&&y+1<n)
{
b[x][y+1]=1;
dfs(x,y+1);
}
if(!b[x][y-1]&&a[x][y-1]=='@'&&y-1>=0)
{
b[x][y-1]=1;
dfs(x,y-1);
}
if(!b[x-1][y-1]&&a[x-1][y-1]=='@'&&x-1>=0&&y-1>=0)
{
b[x-1][y-1]=1;
dfs(x-1,y-1);
}
if(!b[x-1][y+1]&&a[x-1][y+1]=='@'&&x-1>=0&&y+1<n)
{
b[x-1][y+1]=1;
dfs(x-1,y+1);
}
if(!b[x+1][y-1]&&a[x+1][y-1]=='@'&&x+1<m&&y-1>=0)
{
b[x+1][y-1]=1;
dfs(x+1,y-1);
}
if(!b[x+1][y+1]&&a[x+1][y+1]=='@'&&x+1<m&&y+1<n)
{
b[x+1][y+1]=1;
dfs(x+1,y+1);
}
}
int main()
{
int i,j;
while(scanf("%d %d",&m,&n)&&m+n)
{
int sum=0;
memset(b,0,sizeof(b));
getchar();
for(i=0;i<m;i++)
{
for(j=0;j<n;j++)
scanf("%c",&a[i][j]);
getchar();
}
for(i=0;i<m;i++)
for(j=0;j<n;j++)
if(a[i][j]=='@'&&!b[i][j])
{
sum++;
b[i][j]=1;
dfs(i,j);
}
printf("%d\n",sum);
}
return 0;
}
#include<string.h>
char a[102][102];
int m,n,b[102][102];
void dfs(int x,int y)
{
if(!b[x+1][y]&&a[x+1][y]=='@'&&x+1<m)
{
b[x+1][y]=1;
dfs(x+1,y);
}
if(!b[x-1][y]&&a[x-1][y]=='@'&&x-1>=0)
{
b[x-1][y]=1;
dfs(x-1,y);
}
if(!b[x][y+1]&&a[x][y+1]=='@'&&y+1<n)
{
b[x][y+1]=1;
dfs(x,y+1);
}
if(!b[x][y-1]&&a[x][y-1]=='@'&&y-1>=0)
{
b[x][y-1]=1;
dfs(x,y-1);
}
if(!b[x-1][y-1]&&a[x-1][y-1]=='@'&&x-1>=0&&y-1>=0)
{
b[x-1][y-1]=1;
dfs(x-1,y-1);
}
if(!b[x-1][y+1]&&a[x-1][y+1]=='@'&&x-1>=0&&y+1<n)
{
b[x-1][y+1]=1;
dfs(x-1,y+1);
}
if(!b[x+1][y-1]&&a[x+1][y-1]=='@'&&x+1<m&&y-1>=0)
{
b[x+1][y-1]=1;
dfs(x+1,y-1);
}
if(!b[x+1][y+1]&&a[x+1][y+1]=='@'&&x+1<m&&y+1<n)
{
b[x+1][y+1]=1;
dfs(x+1,y+1);
}
}
int main()
{
int i,j;
while(scanf("%d %d",&m,&n)&&m+n)
{
int sum=0;
memset(b,0,sizeof(b));
getchar();
for(i=0;i<m;i++)
{
for(j=0;j<n;j++)
scanf("%c",&a[i][j]);
getchar();
}
for(i=0;i<m;i++)
for(j=0;j<n;j++)
if(a[i][j]=='@'&&!b[i][j])
{
sum++;
b[i][j]=1;
dfs(i,j);
}
printf("%d\n",sum);
}
return 0;
}
相关文章推荐
- HDU 1241 Oil Deposits
- HDU 1241 Oil Deposits
- 【HDU】-1241-Oil Deposits(DFS || BFS&&队列)
- 【HDU】1241--Oil Deposits(DFS)
- hdu 1241 Oil Deposits
- HDU 1241 Oil Deposits(八方向联通块)
- HDU 1241 Oil Deposits (搜索水题)
- HDU 1241 Oil Deposits DFS无回溯 求油田的个数
- hdu 1241 Oil Deposits(dfs入门)
- HDU 1241/UVa572 Oil Deposits(DFS&BFS)
- HDU - 1241 Oil Deposits
- HDU_1241 Oil Deposits(DFS深搜)
- hdu_1241 Oil Deposits
- HDU 1241 Oil Deposits
- HDU 1241 Oil Deposits(dfs)
- HDU 1241 -- Oil Deposits (dfs)
- HDU 1241 Oil Deposits(递归,搜索)
- HDU——1241 Oil deposits(dfs)
- HDU 1241 Oil Deposits(kuangbin带你飞 专题一:基础搜索)
- 【HDU 1241 Oil Deposits】 + DFS || BFS