题目表述

汤姆有一块好田,它是一个n×m方格的矩形,某些方格里面有一些大石头。汤姆有一台播种机。开始的时候,机器位于田地的左上角。机器播种完一个方格后,汤姆就把它开到一个相邻的方格里,继续播种。为了保护机器,汤姆不会把机器开到有石头的方格里面,也不会开到刚刚播种过的方格里面。
汤姆希望在没有石头的方格里面都能播种,这可能吗?

输入

每个测试例的第一行包含两个整数n和m,表示田地的大小。
接下来n行描述田地,每行包含m个字符:‘S’表示方格里面有石头,‘.’表示方格里面没有石头。

输出

对每个测试例,如果汤姆播种完毕,输出“YES”,否则输出“NO”。

代码

#include<bits/stdc++.h>
#define NUM 10
char field[NUM][NUM];  //田地
int n,m;  //田地大小
int visited;     //访问田地中方格的数量
int flag;     //全部播种完毕的标志
int count;     //递归次数统计void dfs(int x,int y)   //坐标
{if ( x<0 || y<0 || x>=n || y>=m) return;if (field[x][y]=='S') return;//已经全部播种完毕if (flag) return;count ++;if (count>1500) return;//将方格里面置为石头,避免重复搜索field[x][y] = 'S';visited ++;   //访问方格计数if (visited == n*m)   //全部方格访问完毕{flag = 1;return;}//分别向4个邻近方格播种dfs(x+1,y);dfs(x-1,y);dfs(x,y+1);dfs(x,y-1);visited --;   //恢复递归状态field[x][y] = '.';
}int main()
{while (scanf("%d%d",&n,&m) && n && m)    //输入田地大小{int i, j;for (i=0; i<n; i++)scanf("%s", field[i]);     //输入方格里面是否为石头visited = 0;for (i = 0; i<n ; i++)for (j = 0; j<m; j++)if (field[i][j]=='S') visited ++;    //有石头则访问+1flag = 0;    //初始化count = 0;dfs(0,0);    //从(0,0)处开始递归处理if (flag) printf("YES\n");else printf("NO\n");}return 0;
}

Seeding(深度优先遍历)相关推荐

  1. 实验报告C语言实现图的深度遍历,图的深度优先遍历的C语言实现.pdf

    图的深度优先遍历的C语言实现.pdf 维普资讯 九 江 职 业 技 术 学 院 学 报 JournalofJiujiangVocational&TechnicalCollege 2004.2 ...

  2. 数据结构与算法(7-2)图的遍历(深度优先遍历DFS、广度优先遍历BFS)(分别用邻接矩阵和邻接表实现)

    目录 深度优先遍历(DFS)和广度优先遍历(BFS)原理 1.自己的原理图 2.官方原理图 一.邻接矩阵的深度优先遍历(DFS) 1.原理图 2. 过程: 3.总代码 二.邻接表的深度优先遍历(DFS ...

  3. 用python深度优先遍历解迷宫问题

    这篇文章主要给大家介绍了关于python迷宫问题深度优先遍历的相关资料,深度优先搜索算法(Depth-First-Search),是搜索算法的一种,需要的朋友可以参考下 一.迷宫介绍 用python解 ...

  4. 三十二、图的创建深度优先遍历(DFS)广度优先遍历(BFS)

    一.图的基本介绍 为什么要有图 前面我们学了线性表和树 线性表局限于一个直接前驱和一个直接后继的关系 树也只能有一个直接前驱也就是父节点 当我们需要表示多对多的关系时, 这里我们就用到了图. 图的举例 ...

  5. 深度优先遍历_二叉树的深度优先遍历,理解框架真的能够套用题目吗?不了解执行过程可能很难。...

    显然这是一个很普通的二叉树的深度优先遍历,从中可以提取出这样的框架: class TreeNode { int val; TreeNode left, right; } public void isF ...

  6. 数据结构 图的深度优先遍历 C

    分享一下我老师大神的人工智能教程!零基础,通俗易懂!http://blog.csdn.net/jiangjunshow 也欢迎大家转载本篇文章.分享知识,造福人民,实现我们中华民族伟大复兴! Bool ...

  7. 二叉树深度优先遍历和广度优先遍历

    二叉树深度优先遍历和广度优先遍历

  8. 多级树的深度优先遍历与广度优先遍历(Java实现)

    目录 多级树的深度优先遍历与广度优先遍历(Java实现) 节点模型 深度优先遍历 广度优先遍历 多级树的深度优先遍历与广度优先遍历(Java实现) 深度优先遍历与广度优先遍历其实是属于图算法的一种,多 ...

  9. 二叉树的深度优先遍历和广度优先遍历

    二叉树是一种很重要的数据结构,对于二叉树的遍历,有深度优先遍历和广度优先遍历,深度优先遍历又有先序.中序.后续遍历,广度优先遍历就是按层遍历. 1. 深度优先遍历 深度优先遍历,也就是先序.中序.后续 ...

  10. 图 深度优先遍历 广度优先遍历 非递归遍历 图解算法过程

    图的邻接矩阵表示 通常图的表示有两种方法:邻接矩阵,邻接表. 本文用邻接矩阵实现,一是代码量更少,二是代码风格也更贴近C语言.但不论是图的哪种实现方式,其基本的实现思想是不变的. 1:节点的信息,我们 ...

最新文章

  1. 直流耦合and交流耦合
  2. 扒一扒.NET Core的环境配置提供程序
  3. 查询 service monitor 时发生内部错误_通过Service访问应用 (1)
  4. qstandarditemmodel 重写data函数后无法实现拖拽_实现类似百度网盘上传的功能
  5. 前端学习(171):注释元素
  6. python动态获取cookie_看到很多人求助python 我也求助一下如何写cookie的获取和登录吧...
  7. VBS操作XML文档,拷贝结点 (转)
  8. 【ArcGIS|空间分析|网络分析】2 创建多模式网络数据集
  9. linux中生成考核用的NTFS文件系统结构样例(一)
  10. 18.Linux软件安装之Rpm安装
  11. junit单元测试步骤
  12. seaweedfs java api_seaweedfs代码详解
  13. Data Shapley: Equitable Valuation of Data for Machine Learning(翻译)
  14. 伽罗瓦2^8域下模多项式求逆python(查表)实现
  15. 重要的xcel文件e报表丢了如何恢复呢
  16. 年轻时欠下风流情债的十大男女明星(组图)
  17. Let's Encrypt 客户端将由EFF管理
  18. 实用干货 !这才是职场最全实用建议
  19. python 批量处理图片
  20. python输入一个数字n、计算1到n的和_python用户输入一个整数N,计算并输出1到N相加的和,请问这个程序错在哪里了?...

热门文章

  1. 勘探重力实验matlab,MATLAB在重力图制作中的应用
  2. 中国招聘网站调研报告
  3. Teradata:数据可视化与模型优化相辅相成
  4. 完全背包问题(师从yxc,闫氏Dp)
  5. Android-代码设置TextView字体加粗或者不加粗
  6. mongodb可视化工具 mac版 Studio 3T破解
  7. 编译原理:LL(1)文法 语法分析器(预测分析表法)
  8. linux终端打英文间隔太大,解决vs code 内置终端,字体间隔过大问题。(linux centos7成功)...
  9. HTML内嵌pdf在ios设备上无法正常显示
  10. ant vue 的datepicker类组件中英文混合显示解决