国产探花免费观看_亚洲丰满少妇自慰呻吟_97日韩有码在线_资源在线日韩欧美_一区二区精品毛片,辰东完美世界有声小说,欢乐颂第一季,yy玄幻小说排行榜完本

首頁 > 編程 > C > 正文

C語言實現圖的搜索算法示例

2020-01-26 14:05:52
字體:
來源:轉載
供稿:網友

本文實例講述了C語言實現圖的搜索算法。分享給大家供大家參考,具體如下:

在游戲中,常常遇到路徑規劃問題,用到圖的相關算法,我們以簡單圖來學習。

圖通常有兩種表示方式,矩陣和鄰接表。矩陣表示簡單,運算快,但當矩陣是稀疏矩陣的時候就存在空間浪費的問題,并且效率也會下降,而鄰接表節約空間,并且由于邊是連續訪問,時間效率也比較高。在本文中,我們將以鄰接表來表示圖。

#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;}

希望本文所述對大家C語言程序設計有所幫助。

發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表

圖片精選

主站蜘蛛池模板: 木兰县| 通许县| 五常市| 久治县| 黑山县| 普兰县| 龙江县| 西平县| 永德县| 日土县| 南川市| 镇远县| 岐山县| 景泰县| 曲周县| 泾源县| 什邡市| 车致| 西充县| 临泽县| 偃师市| 乐业县| 安阳县| 湟源县| 天长市| 防城港市| 黄陵县| 隆尧县| 汾西县| 双鸭山市| 红原县| 敦化市| 昔阳县| 海晏县| 乳山市| 潼关县| 威信县| 开远市| 德庆县| 康马县| 威信县|