zoj2100seeding(DFS)
2015-08-20 20:53
393 查看
Seeding
Time Limit: 2 Seconds
Memory Limit: 65536 KB
It is spring time and farmers have to plant seeds in the field. Tom has a nice field, which is a rectangle with n * m squares. There are big stones in some of the squares.
Tom has a seeding-machine. At the beginning, the machine lies in the top left corner of the field. After the machine finishes one square, Tom drives it into an adjacent square, and continues seeding. In order to protect the machine, Tom will not drive it
into a square that contains stones. It is not allowed to drive the machine into a square that been seeded before, either.
Tom wants to seed all the squares that do not contain stones. Is it possible?
Input
The first line of each test case contains two integers n and m that denote the size of the field. (1 < n, m < 7) The next n lines give the field, each of which contains m characters. 'S' is a square with stones, and '.' is a square without stones.
Input is terminated with two 0's. This case is not to be processed.
Output
For each test case, print "YES" if Tom can make it, or "NO" otherwise.
Sample Input
4 4
.S..
.S..
....
....
4 4
....
...S
....
...S
0 0
Sample Output
YES
NO
题目大意:
Tom想把自己的地里播种完种子,条件是:(1)有石头的地方不能播种,(2)已经播种好的不能再播种,问汤姆最后能否将土地全部都种上种子;
解题思路:DFS搜索+回溯;(即当遇到不满足的的位置回溯到该位置的上一个位置然后从此位置向下一个可以走继续搜索直到所有的点都搜索到)
每走完一个位置就将其赋为“S”,并不断统计图中“S”(即石头)的个数cnt,如果有cnt == N*M(即图中所有未播种的位置都能播种)代表可以将土地上能播种的地方都种上;
否则就不可以;
Time Limit: 2 Seconds
Memory Limit: 65536 KB
It is spring time and farmers have to plant seeds in the field. Tom has a nice field, which is a rectangle with n * m squares. There are big stones in some of the squares.
Tom has a seeding-machine. At the beginning, the machine lies in the top left corner of the field. After the machine finishes one square, Tom drives it into an adjacent square, and continues seeding. In order to protect the machine, Tom will not drive it
into a square that contains stones. It is not allowed to drive the machine into a square that been seeded before, either.
Tom wants to seed all the squares that do not contain stones. Is it possible?
Input
The first line of each test case contains two integers n and m that denote the size of the field. (1 < n, m < 7) The next n lines give the field, each of which contains m characters. 'S' is a square with stones, and '.' is a square without stones.
Input is terminated with two 0's. This case is not to be processed.
Output
For each test case, print "YES" if Tom can make it, or "NO" otherwise.
Sample Input
4 4
.S..
.S..
....
....
4 4
....
...S
....
...S
0 0
Sample Output
YES
NO
题目大意:
Tom想把自己的地里播种完种子,条件是:(1)有石头的地方不能播种,(2)已经播种好的不能再播种,问汤姆最后能否将土地全部都种上种子;
解题思路:DFS搜索+回溯;(即当遇到不满足的的位置回溯到该位置的上一个位置然后从此位置向下一个可以走继续搜索直到所有的点都搜索到)
每走完一个位置就将其赋为“S”,并不断统计图中“S”(即石头)的个数cnt,如果有cnt == N*M(即图中所有未播种的位置都能播种)代表可以将土地上能播种的地方都种上;
否则就不可以;
#include<stdio.h> #include<string.h> char map[10][10]; int n,m,cnt,k; void dfs(int x,int y) { if(cnt==n*m) //可以都播种上,k = 1; { k=1; return; } if(x<0||x>=n||y<0||y>=m) //判断是否越界; return ; if(map[x][y]=='S') //判断是否是石头或已种过; return ; cnt++; map[x][y]='S'; dfs(x-1,y); dfs(x,y-1); dfs(x,y+1); dfs(x+1,y); cnt--; //当进入死角时;回溯到上一个位置; map[x][y]='.'; } int main() { int i,j; while(scanf("%d%d",&n,&m)&&(n|m)) { cnt=0;k=0; memset(map,0,sizeof(map)); for(i=0;i<n;i++) { getchar(); for(j=0;j<m;j++) { scanf("%c",&map[i][j]); if(map[i][j]=='S') //记录初始图中"S"的个数; cnt++; } } dfs(0,0); if(k==1) printf("YES\n"); else printf("NO\n"); } return 0; }
相关文章推荐
- event
- 黑马程序员——正则与反射
- HDU 5407 CRB and Candies (2015多校第10场第一题)素数打表,除法取模(乘法逆元)
- poj 3590
- 程序员的生活充满压力,但你不能放弃!
- HDU 1465 不容易系列之排错
- 最少转弯问题
- 明远imx6
- 第六篇 SQL Server安全执行上下文和代码签名
- Cocos2d-x 之 八方向小摇杆
- 【ZJOI2013】K 大数查询 ( 树状数组套线段树 )
- css基础精华05
- HDU 5414 CRB and String
- Centos7下Amarok播放mp3
- curl 要么 file_get_contents 获得授权页面的方法的必要性
- hive与hbase集成
- Heartbeat概念详解
- 如何隐藏导航栏下的线
- css基础精华04
- Java值传递以及引用的传递、数组的传递!!