[C语言] 深度遍历的方法
来源:互联网 发布:安卓录屏软件不用root 编辑:程序博客网 时间:2024/05/22 00:11
题意是:对于一个二维数组 默认是 m*m; 要求从一个点 开始出发,在不重复 的情况下 遍历 图中的所有的点,有多少种情况
深度遍历其实是一个非常费时间的算法,但是理解也算是很好理解的算法,
深度算法的用到的是递归的简单粗暴的方法! 当你理解了递归后,解决很多问题都能很简单粗暴了
什么是递归,递归 就是在不断的调用自己(也是在压栈的过程,结束的过程就是出栈的过程,而栈中保存的是变量,出栈的时候,则是将全局变量返回,局部变量不返回)
比如上面的题意,在每一点的时候 ,有四中情况选择, 只要到临界点的时候才会结束
什么是临界点,临界点就是完成一趟完整的遍历
否则的情况下选择下一个点,如果该点结束所有的查找,那么就是出栈 ,返回上一次调用自身调用的地方
// 深度优化搜索#include <stdio.h>#include <stdlib.h>#define MAX_1 3 //用来设定循环最大数#define MAX 4 //用来设置数组的大小,只需要改变以上两个值就可以了 保证 MAX = MAX_1 + 1,可以改变图的大小int map[MAX][MAX]; //用二维数组来保存图int book[MAX][MAX],m,n,add=2,sum; //标记已经访问过的点, add: 将以此增加访问过的点,sum: 总共的情况int maxmax = MAX*MAX+1; //表示图中点的个数int next[4][2]={ // 表示可能寻找的方向 {0,1}, {1,0}, {0,-1}, {-1,0} };int dfs(int a,int b){ int q,tx,ty; if(add == maxmax && sum <= 5) // 用来显示前五个可能的情况 { for(n=0;n<=MAX_1;n++) { for(m=0;m<=MAX_1;m++) { printf("%d\t",map[n][m]); } printf("\n"); } sum++; printf("-------------------\n"); } if( add == maxmax && sum > 5) // { sum++; } for(q = 0;q <= 3; q++) //遍历所有能下一步的方向的点 { tx = a + next[q][0]; ty = b + next[q][1]; if(tx > MAX_1 || ty > MAX_1 || tx < 0 || ty < 0 ) { continue; } if(book[tx][ty] == 0) { map[tx][ty] = add; add++; book[tx][ty] = 1; dfs(tx,ty); book[tx][ty] = 0; add--; } } return;}int main(){ int i,j,x,y ,x1,y1; for(i=0;i<=MAX_1;i++) { for(j=0;j<=MAX_1;j++) { map[i][j] = 0; } } for(i=0;i<=MAX_1;i++) { for(j=0;j<=MAX_1;j++) { book[i][j] = 0; } } printf("输入起始点<两个数大小在 1-%d 之间>: ",MAX); scanf("%d",&x1); scanf("%d",&y1); x = x1 - 1; y = y1 - 1; printf("x:%d y:%d \n",x,y); map[x][y] = 1; book[x][y] = 1; dfs(x,y); printf("总共有: %d情况\n",sum); return 0;}
0 0
- [C语言] 深度遍历的方法
- C语言 图的深度 遍历
- 图的深度优先遍历-C语言实现
- C语言非连通图的深度优先遍历
- c语言遍历字符串数组的方法
- 图的邻接表存储 深度优先遍历 广度优先遍历 C语言实现
- 图的邻接矩阵存储 深度优先遍历 广度优先遍历 C语言实现
- 图的邻接表存储 深度优先遍历 广度优先遍历 C语言实现
- 深度优先遍历与广度优先遍历算法的C语言实现
- c语言实现图的深度优先遍历和广度优先遍历
- C语言实现图的邻接矩阵存储结构及深度优先遍历和广度优先遍历
- 深度遍历(DFS)与广度遍历(BFS) (C语言实现)
- 八.二叉树各种操作的C语言实现 深度遍历求深度,广度遍历求深度,交换左右子树,求叶子节点数
- C语言不用任何参数遍历数组的方法
- C语言实现二叉树的基本操作---创建、遍历、求深度、求叶子结点
- C语言实现二叉树的基本操作---创建、遍历、求深度、求叶子结点
- C语言实现二叉树的各种遍历及求解深度
- C语言实现二叉树的各种遍历及求解深度
- java.lang.IllegalMonitorStateException
- swoole-swoole是什么能做什么
- 华为荣耀6 安装失败
- JAVA设计模式之单例模式
- VGA连接电平转换适用芯片,匹配电平
- [C语言] 深度遍历的方法
- tomcat的类加载机制
- nyoj117——用归并排序求逆序数
- 程序员是怎样撩到一个女朋友的?
- Android-FilePicker 选择照片
- log4j:WARN No appenders could be found for logger (org.hibernate.cfg.Environment). log4j:WARN Please
- 自定义开发的系统整合 office Web apps
- iOS学习笔记-021.UIScrollView分页
- cf 8VC Venture Cup 2017 C