深度优先搜索(deep first search)
来源:互联网 发布:提花组织软件 编辑:程序博客网 时间:2024/06/07 01:04
深度优先搜索是一种在开发爬虫早期使用较多的方法。它的目的是要达到被搜索结构的叶结点(即那些不包含任何超链的HTML文件) 。在一个HTML文件中,当一个超链被选择后,被链接的HTML文件将执行深度优先搜索,即在搜索其余的超链结果之前必须先完整地搜索单独的一条链。深度优先搜索沿着HTML文件上的超链走到不能再深入为止,然后返回到某一个HTML文件,再继续选择该HTML文件中的其他超链。当不再有其他超链可选择时,说明搜索已经结束。
深度搜索应用的方面有很多,八皇后问题:
http://blog.csdn.net/q623702748/article/details/51108818
在图方面的应用,深度搜索的思路就是按一定顺序向四周搜索,如果碰壁了就回溯。但是深度搜索找出的路径不一定是最优的,而且深度搜索带来的时间代价是不确定的,是根据你遍历的顺序决定的,如果图特别大,如果方向找错了,从起点到终点的代价是非常大的。
代码如下:
#define _CRT_SECURE_NO_WARNINGS #include <iostream>using namespace std;/************************************************************************//* 深度优先搜索(dfs) *//************************************************************************/enum { ROW = 7, COL = 7 };struct Node{int x;int y;friend istream &operator>>(istream &in, Node &node){in >> node.x >> node.y;return in;}};int map[ROW][COL] = {{ 0, 0, 1, 0, 1, 0, 1 },{ 1, 0, 0, 1, 0, 0, 1 },{ 1, 0, 1, 0, 0, 1, 0 },{ 1, 0, 0, 1, 0, 0, 1 },{ 0, 0, 0, 1, 0, 0, 1 },{ 1, 0, 1, 0, 0, 0, 1 },{ 1, 0, 0, 0, 1, 0, 1 },};bool vis[ROW][COL] = { 0 };int dir[4][2] = {{ -1, 0 }, { 0, 1 }, { 1, 0 }, { 0, -1 }};bool dfs(Node cur, Node dest){if (cur.x == dest.x && cur.y == dest.y) return true;int dir_x = cur.x;int dir_y = cur.y;if (map[dir_x][dir_y] != 1)//不在障碍物上面{for (int i = 0; i < 4; i++){int new_x = dir_x + dir[i][0];int new_y = dir_y + dir[i][1];//新产生的坐标是否已经在上一轮被访问过,或者该点是否为障碍物if (new_x >= 0 && new_y >= 0 && new_x < ROW&&new_y < COL && !vis[new_x][new_y] && !map[new_x][new_y]){Node n_cur = { new_x, new_y };vis[new_x][new_y] = true;//表示已经被访问if (dfs(n_cur, dest)){map[new_x][new_y] = 2;//若找到,则将路径标出,记号为2return true;}vis[new_x][new_y] = false;//取消标记,否则会影响下一轮操作}}}return false;//返回false,继续遍历}void init(){memset(vis, 0, sizeof(vis));for (int i = 0; i < ROW;i++)for (int j = 0; j < COL; j++){if (map[i][j] == 2)map[i][j] = 0;}}void print_map(){for (int i = 0; i < ROW; i++){for (int j = 0; j < COL; j++)std::cout << map[i][j] << " ";std::cout << std::endl;}}int main(void){Node cur = { 0, 0 };Node dest = { 3, 1 };print_map();while (cin >> cur >> dest){init();if (map[cur.x][cur.y] != 1 && map[dest.x][dest.y] != 1){map[cur.x][cur.y] = 2;if (dfs(cur, dest)){std::cout << "找到了" << std::endl;}else{std::cout << "找不到" << std::endl;}}print_map();system("pause");system("cls");init();print_map();}cout << endl;system("pause");return 0;}
1 0
- 深度优先搜索(deep first search)
- 深度优先搜索(Depth-First-Search)
- 深度优先搜索算法(Depth first search)
- 深度优先搜索算法(Depth-First-Search)
- 图的深度优先搜索(Depth First Search,DFS)
- 5.3.2 深度优先搜索(Depth-First-Search,DFS)
- DFS-深度优先搜索(Depth First Search)—1
- [数据结构]深度优先搜索算法(Depth-First-Search,DFS)
- TensorFlow中的深度优先搜索(Depth-first search, DFS)
- 深度优先搜索(Depth-First-Search,DFS)
- 穷竭搜索之深度优先搜索DFS(Depth-First Search)
- 图的深度优先搜索/Depth-first search/C++
- 图的深度优先搜索(Depth First Search)
- 深度优先搜索Depth-first search (DFS) for undirected graphs
- DFS --- Depth First Search 深度优先搜索算法
- 图的深度优先搜索/Depth-first search/C++
- 深度优先搜索DFS(depth first search),拓扑排序
- 图的深度优先搜索/Depth-first search/C++
- 数论:复合数模的任意次同余式
- ACM: 几何题+hash题 poj 2002
- ACM: 简单排序题 poj 2231 动动脑…
- 动态规划: 装配线调度问题 (算法导…
- ACM: 矩阵链乘 动态规划题 poj 165…
- 深度优先搜索(deep first search)
- ACM: 矩阵快速幂运算 数论题 poj 3…
- leetcode 168. Excel Sheet Column Title-表格栏目|进制转换
- ACM: 经过K条边的最短路 图论题 po…
- 1019
- ACM: 矩阵建模 数论题 poj 3735 (…
- ACM: 二分又二分 数论题 poj 3233
- SeaJS与RequireJS最大的区别
- ACM: 矩阵变形题 数论题 poj 3150