图的搜索算法
来源:互联网 发布:淘宝怎么搜二手 编辑:程序博客网 时间:2024/04/30 08:21
在游戏中,常常遇到路径规划问题,用到图的相关算法,我们以简单图来学习。
图通常有两种表示方式,矩阵和邻接表。矩阵表示简单,运算快,但当矩阵是稀疏矩阵的时候就存在空间浪费的问题,并且效率也会下降,而邻接表节约空间,并且由于边是连续访问,时间效率也比较高。在本文中,我们将以邻接表来表示图。
#include<queue>#include<stack>using namespace std;struct SE{int vIndex;int tag;SE* next;};struct SMap{SE* pE;int nnode;};void visit(SE *se){printf("%d\n", se->vIndex);}SMap* create_map(int matrix[][6], int n){SMap* pMap = new SMap();pMap->nnode = n;pMap->pE = new SE[n];memset(pMap->pE, 0, n*sizeof(SE));for (int i = 0; i<n; i++){pMap->pE[i].vIndex = i;pMap->pE[i].tag = 0;SE* p = &pMap->pE[i];for (int j = 0; j<n; j++){if (matrix[i][j] != 0){p->next = new SE();p->next->vIndex = j;p->next->tag = 0;p->next->next = NULL;p = p->next;}}}return pMap;}int BFS(SMap* pMap, int n){queue<SE*> q;for (int i = 0; i < n; i++){if (pMap->pE[i].tag == 0){q.push(&pMap->pE[i]);while (!q.empty()){SE *se = q.front();q.pop();if (pMap->pE[se->vIndex].tag == 1){continue;}visit(se);pMap->pE[se->vIndex].tag = 1;SE * p = se;while (p->next){p = p->next;if (pMap->pE[p->vIndex].tag == 0){q.push(p);}}}}}return 0;}int DFS(SMap* pMap, int n){stack<SE*> s;for (int i = 0; i < n; i++){if (pMap->pE[i].tag == 0){s.push(&pMap->pE[i]);while (!s.empty()){SE *se = s.top();s.pop();if (pMap->pE[se->vIndex].tag == 1){continue;}visit(se);pMap->pE[se->vIndex].tag = 1;SE * p = &pMap->pE[se->vIndex];stack<SE*> tmp;while (p->next){p = p->next;if (pMap->pE[p->vIndex].tag == 0){tmp.push(p);}}while (!tmp.empty()){s.push(tmp.top());tmp.pop();}}}}return 0;}int main(){int map[6][6] = {{ 0, 1, 0, 1, 0, 0 },{ 1, 0, 1, 1, 1, 0 },{ 0, 1, 0, 1, 0, 0 },{ 1, 1, 1, 0, 1, 0 },{ 0, 1, 0, 1, 0, 1 },{ 0, 0, 0, 0, 1, 0 }};SMap* smap = create_map(map, 6);//BFS(smap, 6);DFS(smap, 6);return 0;}
0 0
- 图的搜索算法
- 图的搜索算法
- 图搜索的通用算法
- 图的搜索算法javascript
- 图搜索算法(一):图搜索的一般算法
- 搜索算法-搜索的优化
- 算法导论-图的搜索算法之深度优先搜索和广度优先搜索
- 图的搜索算法之广度优先搜索
- 图的基础算法-广度优先搜索/深度优先搜索
- 基本图算法之图的搜索
- 基本图算法之图的搜索
- 图的广度优先搜索算法实现
- 图的搜索算法(一)
- 图的搜索算法(二)
- 图的搜索算法(三)
- 图的搜索算法(四)
- 四、图的深度优先搜索算法
- 图的深度优先搜索算法DFS
- excel合并含合并同类项的导出
- 一个App调用另一个App的Activity的方法
- Hadoop: the definitive guide 第三版 拾遗 第四章 之MapFile
- 安装cdh4.5工具cloudera manager
- vs2013设置winpcap开发环境
- 图的搜索算法
- matlab 同个坐标下的两个函数图像的比较
- HDU2084
- android 手机不能发短信
- 从Blue Pill、硬件虚拟化谈安全防护完备性上的一个小原则
- C++编程规范指47.以同样的顺序定义和初始化成员变量
- Matlab科学图表美化——漫画式图表
- Mysql数据库5.6.10 error 2003 hy000
- JS之时间显示问题