C語言實(shí)現(xiàn)圖的搜索算法示例
本文實(shí)例講述了C語言實(shí)現(xiàn)圖的搜索算法。分享給大家供大家參考,具體如下:
在游戲中,常常遇到路徑規(guī)劃問題,用到圖的相關(guān)算法,我們以簡單圖來學(xué)習(xí)。
圖通常有兩種表示方式,矩陣和鄰接表。矩陣表示簡單,運(yùn)算快,但當(dāng)矩陣是稀疏矩陣的時候就存在空間浪費(fèi)的問題,并且效率也會下降,而鄰接表節(jié)約空間,并且由于邊是連續(xù)訪問,時間效率也比較高。在本文中,我們將以鄰接表來表示圖。
#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語言程序設(shè)計有所幫助。
相關(guān)文章
解讀堆排序算法及用C++實(shí)現(xiàn)基于最大堆的堆排序示例
把待排序的數(shù)組構(gòu)造出最大堆是進(jìn)行堆排序操作的基本方法,這里將帶大家來解讀堆排序算法及用C++實(shí)現(xiàn)基于最大堆的堆排序示例,首先從堆排序的概念開始:2016-06-06
C++ 風(fēng)靡一時的連連看游戲的實(shí)現(xiàn)流程詳解
游戲“連連看”是源自臺灣的桌面小游戲,自從流入大陸以來風(fēng)靡一時,也吸引眾多程序員開發(fā)出多種版本的“連連看”。這其中,顧芳編寫的“阿達(dá)連連看”以其精良的制作廣受好評,這也成為顧方“阿達(dá)系列軟件”的核心產(chǎn)品。并于2004年,取得國家版權(quán)局的計算機(jī)軟件登記證書2021-11-11
C語言非遞歸算法解決快速排序與歸并排序產(chǎn)生的棧溢出
上期我們講完了排序算法下,不知道小伙伴們有沒有發(fā)現(xiàn)一個問題,快速排序和歸并排序我們都是用遞歸來實(shí)現(xiàn)的,可能有小伙伴會問,如果說數(shù)據(jù)量很多話,棧區(qū)空間會不會不夠用呢?這期我們就來解決使用遞歸實(shí)現(xiàn)的排序?qū)е聴R绯鋈绾谓鉀Q2022-04-04

