亚洲乱码中文字幕综合,中国熟女仑乱hd,亚洲精品乱拍国产一区二区三区,一本大道卡一卡二卡三乱码全集资源,又粗又黄又硬又爽的免费视频

C/C++淺析鄰接表拓?fù)渑判蛩惴ǖ膶?shí)現(xiàn)

 更新時(shí)間:2022年07月27日 10:20:44   作者:菠菠蘿寶  
這篇文章主要介紹了C/C++對(duì)于鄰接表拓?fù)渑判蛩惴ǖ膶?shí)現(xiàn),鄰接表是圖的一種鏈?zhǔn)酱鎯?chǔ)方法,其數(shù)據(jù)結(jié)構(gòu)包括兩部分:節(jié)點(diǎn)和鄰接點(diǎn)

前言

在軟件開(kāi)發(fā)、施工過(guò)程、教學(xué)安排等等的一系列活動(dòng)中,往往需要一個(gè)有向無(wú)環(huán)圖來(lái)表示其是否成成功進(jìn)行下去。

在一個(gè)有向圖為頂點(diǎn)表示活動(dòng)的網(wǎng)中,我們稱(chēng)為AOV網(wǎng)(Activity On Vertex Network)。設(shè)G={V,E}是一個(gè)具有n個(gè)頂點(diǎn)的有向圖,V中的頂點(diǎn)序列v1,v2,…,vn,滿(mǎn)足若從頂點(diǎn)vi到vj有一條路徑,則在頂點(diǎn)序列中頂點(diǎn)vi必在vj之前。則我們稱(chēng)這樣的頂點(diǎn)為一個(gè)拓?fù)湫蛄小?/p>

所謂拓?fù)渑判颍鋵?shí)就是對(duì)一個(gè)有向圖構(gòu)造拓?fù)湫蛄械倪^(guò)程。如果所有的頂點(diǎn)被輸出,則說(shuō)明有向圖中不存在回路,反之則是有回路。

一、拓?fù)渑判蛩惴ǖ乃悸?/h2>

拓?fù)渑判蛲迷谟邢蜞徑颖碇?,這里也就只用有向鄰接表來(lái)實(shí)現(xiàn)。

先找出所有節(jié)點(diǎn)的入度。

再在AOV網(wǎng)中選擇一個(gè)入度為0的頂點(diǎn)輸出,然后刪除此頂點(diǎn),將其連接的節(jié)點(diǎn)的入度減一直至輸出所有頂點(diǎn)或者AOV網(wǎng)中不存在入度為0的頂點(diǎn)為止。

二、實(shí)現(xiàn)步驟

1.求個(gè)頂點(diǎn)的入度

設(shè)置一個(gè)indegree數(shù)組來(lái)存放各個(gè)頂點(diǎn)的入度。

int* indegree = (int*)malloc(sizeof(int) * G.vexnum);
//對(duì)單個(gè)節(jié)點(diǎn)p求入度
void CountIndegree(AdjList g, int* indegree, ArcNode* p) {
	while (p != NULL) {
		indegree[p->adjvex]++;
		p = p->nextarc;
	}
	return;
}

2.拓?fù)渑判虻膶?shí)現(xiàn)

這里對(duì)棧的使用還是調(diào)用stl中的stack,比較方便。

bool TopoSort(AdjList g, int* indegree) {
	//先清空申請(qǐng)的indegree數(shù)組,或者也可以在初始化時(shí)采用calloc,就不用在這里置為0了
	for (int i = 0; i < g.vexnum; i++) {
		indegree[i] = 0;
	}
	//遍歷邊表中的每一個(gè)頂點(diǎn),用CountIndegree()遍歷單個(gè)節(jié)點(diǎn)
	for (int i = 0; i < g.vexnum; i++) {
		ArcNode* p = g.vertexlist[i].firstarc;
		CountIndegree(g, indegree, p);
	}
	stack<int>S;
	//如果該頂點(diǎn)的入度為0,則入棧。
	for (int i = 0; i < g.vexnum; i++) {
		if (indegree[i] == 0) {
			S.push(i);
		}
	}
	//count用來(lái)表示已經(jīng)輸出的節(jié)點(diǎn)個(gè)數(shù)
	//如果所有的頂點(diǎn)被輸出,則count==g.vexnum,無(wú)回路,反之count<g.vexnum,則是有回路。
	int count = 0;
	while (!S.empty()) {
		int top = S.top();
		printf("%c ", g.vertexlist[top].data);
		S.pop();
		count++;
		ArcNode* p = g.vertexlist[top].firstarc;
		for (p; p != NULL; p = p->nextarc) {
			int i = p->adjvex;
			if (--indegree[i] == 0) {
				S.push(i);
			}
		}
	}
	if (count == g.vexnum) {
		return true;
	}
	return false;
}

三、測(cè)試結(jié)果

自己花了一個(gè)看起來(lái)挺復(fù)雜的圖,一下也看不出來(lái)有沒(méi)有環(huán)

首先算一算入度,順帶打印一下。

接下來(lái)是拓?fù)渑判虻慕Y(jié)果

完美!

總結(jié)

每個(gè)頂點(diǎn)進(jìn)棧一次出戰(zhàn)一次,度減一的操作執(zhí)行了e次,所以整個(gè)算法的時(shí)間復(fù)雜度為O(n+e)。

到此這篇關(guān)于C/C++淺析鄰接表拓?fù)渑判蛩惴ǖ膶?shí)現(xiàn)的文章就介紹到這了,更多相關(guān)C++拓?fù)渑判騼?nèi)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!

相關(guān)文章

  • C++設(shè)置超時(shí)時(shí)間的簡(jiǎn)單實(shí)現(xiàn)方法

    C++設(shè)置超時(shí)時(shí)間的簡(jiǎn)單實(shí)現(xiàn)方法

    這篇文章主要介紹了C++設(shè)置超時(shí)時(shí)間的簡(jiǎn)單實(shí)現(xiàn)方法,涉及系統(tǒng)函數(shù)setsockopt對(duì)套接口的操作,具有一定的實(shí)用價(jià)值,需要的朋友可以參考下
    2014-10-10
  • C語(yǔ)言二維數(shù)組應(yīng)用之掃雷游戲

    C語(yǔ)言二維數(shù)組應(yīng)用之掃雷游戲

    這篇文章主要為大家詳細(xì)介紹了C語(yǔ)言二維數(shù)組應(yīng)用之掃雷游戲,文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下
    2022-06-06
  • C語(yǔ)言實(shí)現(xiàn)鏈隊(duì)列基本操作

    C語(yǔ)言實(shí)現(xiàn)鏈隊(duì)列基本操作

    這篇文章主要為大家詳細(xì)介紹了C語(yǔ)言實(shí)現(xiàn)鏈隊(duì)列基本操作,文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下
    2021-09-09
  • 詳解C++?左值引用與?const?關(guān)鍵字

    詳解C++?左值引用與?const?關(guān)鍵字

    這篇文章主要介紹了C++?左值引用與?const?關(guān)鍵字,左值引用是已定義的變量的別名,其主要用途是用作函數(shù)的形參,將?const?關(guān)鍵字用于左值引用時(shí),其在初始化時(shí)可接受的賦值形式變得更加廣泛了,這里來(lái)總結(jié)一下,需要的朋友可以參考下
    2022-09-09
  • 《C++ primer plus》讀書(shū)筆記(二)

    《C++ primer plus》讀書(shū)筆記(二)

    本讀書(shū)筆記是讀了《C++ primer plus(第六版)》第五至八章的學(xué)習(xí)筆記。是C++讀書(shū)筆記系列的第二篇。復(fù)習(xí)C++基礎(chǔ)知識(shí)的可以瞄瞄。
    2014-10-10
  • C++實(shí)現(xiàn)學(xué)校人員管理系統(tǒng)

    C++實(shí)現(xiàn)學(xué)校人員管理系統(tǒng)

    這篇文章主要為大家詳細(xì)介紹了C++實(shí)現(xiàn)學(xué)校人員管理系統(tǒng),文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下
    2022-03-03
  • 解析C++編程中的選擇結(jié)構(gòu)和switch語(yǔ)句的用法

    解析C++編程中的選擇結(jié)構(gòu)和switch語(yǔ)句的用法

    這篇文章主要介紹了解析C++編程中的選擇結(jié)構(gòu)和switch語(yǔ)句的用法,是C++入門(mén)學(xué)習(xí)中的基礎(chǔ)知識(shí),需要的朋友可以參考下
    2015-09-09
  • c++讀取excel的代碼詳解

    c++讀取excel的代碼詳解

    在本篇文章里小編給大家分享的是一篇關(guān)于c++讀取excel的代碼詳解內(nèi)容,需要的朋友們可以學(xué)習(xí)參考下。
    2020-02-02
  • Clion-MinGW編譯后的exe文件添加ico圖標(biāo)的操作方法

    Clion-MinGW編譯后的exe文件添加ico圖標(biāo)的操作方法

    這篇文章主要介紹了Clion-MinGW編譯后的exe文件添加ico圖標(biāo)的操作方法,本文通過(guò)圖文并茂的形式給大家介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下
    2022-07-07
  • C語(yǔ)言進(jìn)階練習(xí)二叉樹(shù)的遞歸遍歷

    C語(yǔ)言進(jìn)階練習(xí)二叉樹(shù)的遞歸遍歷

    樹(shù)是一種重要的非線(xiàn)性數(shù)據(jù)結(jié)構(gòu),直觀(guān)地看,它是數(shù)據(jù)元素(在樹(shù)中稱(chēng)為結(jié)點(diǎn))按分支關(guān)系組織起來(lái)的結(jié)構(gòu),很象自然界中的樹(shù)那樣。樹(shù)結(jié)構(gòu)在客觀(guān)世界中廣泛存在,如人類(lèi)社會(huì)的族譜和各種社會(huì)組織機(jī)構(gòu)都可用樹(shù)形象表示,本篇介紹二叉樹(shù)的遞歸與非遞歸遍歷的方法
    2022-06-06

最新評(píng)論