欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

C語言數(shù)據(jù)結(jié)構(gòu)與算法之圖的遍歷(一)

 更新時(shí)間:2021年12月13日 11:36:47   作者:玄澈_  
這篇文章主要是介紹了利用深度優(yōu)先算法實(shí)現(xiàn)圖的遍歷,文中利用圖文詳細(xì)的介紹了實(shí)現(xiàn)步驟,對(duì)我們學(xué)習(xí)數(shù)據(jù)結(jié)構(gòu)與算法有一定的幫助,需要的朋友可以參考一下

引入?

在數(shù)據(jù)結(jié)構(gòu)中常見的有深度優(yōu)先搜索和廣度優(yōu)先搜索。為什么叫深度和廣度呢?其實(shí)是針對(duì)圖的遍歷而言的,請看下面這個(gè)圖:

圖是由一些小圓點(diǎn)(稱為頂點(diǎn)) 和 連接這些點(diǎn)的直線 (稱為邊)組成的。

例如上圖就是由5個(gè)頂點(diǎn)(編號(hào)為 1,2,3,4,5) 和5條邊(1-2,1-3,1-4,2-4)組成。

現(xiàn)在我們從1號(hào)頂點(diǎn)開始遍歷這個(gè)圖,遍歷就是把圖的每一個(gè)頂點(diǎn)都訪問一次。使用深度優(yōu)先搜索將會(huì)得到如下的結(jié)果。

圖中每個(gè)頂點(diǎn)旁邊的數(shù)表示這個(gè)頂點(diǎn)是第幾個(gè)被訪問到的,我們稱之為 —— 時(shí)間戳?

深度優(yōu)先搜索

使用深度優(yōu)先搜索來遍歷這個(gè)圖的過程:

首先從一個(gè)未走過的頂點(diǎn)作為起始頂點(diǎn),比如以1號(hào)頂點(diǎn)作為起點(diǎn)。沿1號(hào)頂點(diǎn)的邊去嘗試其他它未走過的頂點(diǎn),首先發(fā)現(xiàn)的是2號(hào)頂點(diǎn)還沒被走過,于是來到了2號(hào)頂點(diǎn)。

再以2號(hào)頂點(diǎn)作為出發(fā)點(diǎn)繼續(xù)嘗試訪問其他未走到過的頂點(diǎn),這樣又來到了4號(hào)頂點(diǎn)。

再以4號(hào)頂點(diǎn)作為出發(fā)點(diǎn)繼續(xù)嘗試訪問其他未走過的頂點(diǎn)。但是,此時(shí)在4號(hào)頂點(diǎn)的周圍已經(jīng)沒有其他的頂點(diǎn)了,所以需要返回到2號(hào)頂點(diǎn)。返回到2號(hào)頂點(diǎn)后,發(fā)現(xiàn)沿2號(hào)頂點(diǎn)也不能在訪問到其他未走到的點(diǎn)了,此時(shí)又需要返回到1號(hào)頂點(diǎn)。

繼續(xù)以1號(hào)頂點(diǎn)嘗試訪問其他頂點(diǎn),我們來到了3號(hào)點(diǎn)。以此類推,我們最后來到了5號(hào)點(diǎn)。到此,所以的頂點(diǎn)都走過了,遍歷結(jié)束

深度優(yōu)先搜索的主要思想是:

首先以一個(gè)未被訪問的頂點(diǎn)作為起始頂點(diǎn),沿當(dāng)前頂點(diǎn)的邊走到未被訪問過的頂點(diǎn)

當(dāng)沒有未訪問過的頂點(diǎn)時(shí),則回到上一個(gè)頂點(diǎn),繼續(xù)試探訪問別的頂點(diǎn),直到所有的頂點(diǎn)都被訪問過。

顯然,深度優(yōu)先搜索是沿著圖的某一條分支遍歷直至末端,然后回溯,再沿另一條實(shí)現(xiàn)相同的遍歷,直到所以的頂點(diǎn)都被訪問完為止。

代碼實(shí)現(xiàn)?

上面的二維數(shù)組中 第i行第j列就是表示頂點(diǎn)i到頂點(diǎn)j是否有邊。

1表示有邊,x表示沒有邊,0表示頂點(diǎn)自己到自己。

我們將這種方法稱為 ——? 圖的鄰接矩陣儲(chǔ)存法。?

細(xì)心的朋友可能會(huì)發(fā)現(xiàn)這張圖沿著對(duì)角線全部是0,因?yàn)樯厦孢@張圖是 無向圖。?

所謂無向圖就是指圖的邊沒有方向。例如邊 1 - 5 表示 1號(hào)頂點(diǎn)可以到 5號(hào)頂點(diǎn),5號(hào)頂點(diǎn)也可以到1號(hào)頂點(diǎn)。

接下來就是解決怎么用深度優(yōu)先搜索來實(shí)現(xiàn)遍歷了:

void dfs(int cur)				//cur是當(dāng)前所在的頂點(diǎn)編號(hào)
{
	printf("%d", cur);
	sum++;						//每訪問一個(gè)點(diǎn)就sum++
	if (sum == n) return;		//所有的頂點(diǎn)都訪問過了
	for (i = 1; i <= n; i++)	//從1到n的頂點(diǎn)依次嘗試,看看有哪些頂點(diǎn)與當(dāng)前頂點(diǎn)cur有邊相連
	{
		//判斷當(dāng)前頂點(diǎn)cur到頂點(diǎn)i是否有邊,并判斷頂點(diǎn)i是否已被訪問過
		{
			if (e[cur][i] == 1 && book[i] == 0)
			{
				book[i] = 1;	//標(biāo)記頂點(diǎn)i已經(jīng)訪問過
				dfs(i);			//從頂點(diǎn)i出發(fā)繼續(xù)遍歷
			}
		}
	}
	return;
}

在上面的代碼中 變量 cur 存儲(chǔ)的是當(dāng)前正在遍歷的點(diǎn),二維數(shù)組e存儲(chǔ)的就是圖的邊(鄰接矩陣),數(shù)組book用來標(biāo)記哪些頂點(diǎn)已經(jīng)訪問過,變量sum用來記錄已經(jīng)訪問多少個(gè)頂點(diǎn),變量你存儲(chǔ)的是圖的頂點(diǎn)總個(gè)數(shù)。

完整代碼??

#include <stdio.h>
int book[101], sum, n, e[101][101];
void dfs(int cur)				//cur是當(dāng)前所在的頂點(diǎn)編號(hào)
{
	printf("%d", cur);
	sum++;						//每訪問一個(gè)點(diǎn)就sum++
	if (sum == n) return;		//所有的頂點(diǎn)都訪問過了
	for (i = 1; i <= n; i++)	//從1到n的頂點(diǎn)依次嘗試,看看有哪些頂點(diǎn)與當(dāng)前頂點(diǎn)cur有邊相連
	{
		//判斷當(dāng)前頂點(diǎn)cur到頂點(diǎn)i是否有邊,并判斷頂點(diǎn)i是否已被訪問過
		{
			if (e[cur][i] == 1 && book[i] == 0)
			{
				book[i] = 1;	//標(biāo)記頂點(diǎn)i已經(jīng)訪問過
				dfs(i);			//從頂點(diǎn)i出發(fā)繼續(xù)遍歷
			}
		}
	}
	return;
}
 
int main()
{
	int i, j, m, a, b;
	scanf("%d %d", &n, &m);
	//初始化二維矩陣
	for (i = 1; i <= n; i++)
		for (j = 1; j <= n; j++)
			if (i == j) e[i][j] = 0;
			else e[i][j] = 99999999;	//我們假設(shè)99999999為x
 
	//讀入頂點(diǎn)之間的邊
	for (i = 1; i <= n; i++)
	{
		scanf("%d %d", &a, &b);
		e[a][b] = 1;
		e[b][a] = 1;	//因?yàn)樵搱D為無向圖
	}
 
	//從1號(hào)頂點(diǎn)出發(fā)
	book[1] = 1;  //標(biāo)記1號(hào)頂點(diǎn)已經(jīng)訪問
	dfs(1);		  //從1號(hào)頂點(diǎn)開始遍歷
 
	return 0;
}

到此這篇關(guān)于C語言數(shù)據(jù)結(jié)構(gòu)與算法之圖的遍歷(一)的文章就介紹到這了,更多相關(guān)C語言數(shù)據(jù)結(jié)構(gòu) 圖的遍歷內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!

相關(guān)文章

  • C語言中的文件讀寫fseek 函數(shù)

    C語言中的文件讀寫fseek 函數(shù)

    這篇文章主要介紹是我是C語言中的文件讀寫fseek 函數(shù)的相關(guān)資料,fseek 函數(shù)用來移動(dòng)文件流的讀寫位置;就好比播放器,可以直接拖拽到精彩的時(shí)間點(diǎn)一樣,下面我們就來詳細(xì)介紹該內(nèi)容吧,感興趣的小伙伴可以參考一下
    2021-10-10
  • C語言簡明分析選擇結(jié)構(gòu)和循環(huán)結(jié)構(gòu)的使用

    C語言簡明分析選擇結(jié)構(gòu)和循環(huán)結(jié)構(gòu)的使用

    C語言條件控制語句選擇結(jié)構(gòu),是屬于計(jì)算機(jī)的語言編輯,有在C語言條件控制中的語句選擇結(jié)構(gòu)的存在,即是C語言條件控制語句選擇結(jié)構(gòu),循環(huán)控制語句是一個(gè)基于C語言的編程語句,該語句主要有while循環(huán)語句、do-while循環(huán)語句和for循環(huán)語句來實(shí)現(xiàn)循環(huán)結(jié)構(gòu)
    2022-04-04
  • C語言示例講解if else語句的用法

    C語言示例講解if else語句的用法

    這篇文章主要介紹C語言中的If Else語句怎么使用,在日常操作中,相信很多人在If Else語句怎么使用問題上存在疑惑,小編查閱了各式資料,整理出使用方法,接下來,請跟著小編一起來學(xué)習(xí)吧
    2022-06-06
  • C++三色球問題描述與算法分析

    C++三色球問題描述與算法分析

    這篇文章主要介紹了C++三色球問題描述與算法分析,結(jié)合注釋形式詳細(xì)講述了三色球問題的描述與相應(yīng)的算法設(shè)計(jì)思路,并給出了相關(guān)的實(shí)現(xiàn)方法,需要的朋友可以參考下
    2016-05-05
  • C++ Boost Exception超詳細(xì)講解

    C++ Boost Exception超詳細(xì)講解

    Boost是為C++語言標(biāo)準(zhǔn)庫提供擴(kuò)展的一些C++程序庫的總稱。Boost庫是一個(gè)可移植、提供源代碼的C++庫,作為標(biāo)準(zhǔn)庫的后備,是C++標(biāo)準(zhǔn)化進(jìn)程的開發(fā)引擎之一,是為C++語言標(biāo)準(zhǔn)庫提供擴(kuò)展的一些C++程序庫的總稱
    2022-11-11
  • C語言實(shí)現(xiàn)掃雷小游戲的全過程記錄

    C語言實(shí)現(xiàn)掃雷小游戲的全過程記錄

    這篇文章主要給大家介紹了關(guān)于C語言實(shí)現(xiàn)掃雷小游戲的相關(guān)資料,文中通過示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧
    2021-04-04
  • C++中map和set的簡介及使用詳解

    C++中map和set的簡介及使用詳解

    本文主要介紹了C++中map和set的簡介及使用詳解,文中通過示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下
    2022-02-02
  • 一篇文章帶你了解C++Primer學(xué)習(xí)日記--處理數(shù)據(jù)

    一篇文章帶你了解C++Primer學(xué)習(xí)日記--處理數(shù)據(jù)

    今天小編就為大家分享一篇關(guān)于C++對(duì)數(shù)器的使用講解,小編覺得內(nèi)容挺不錯(cuò)的,現(xiàn)在分享給大家,具有很好的參考價(jià)值,需要的朋友一起跟隨小編來看看吧
    2021-08-08
  • C/C++字符串與數(shù)字互轉(zhuǎn)的實(shí)現(xiàn)

    C/C++字符串與數(shù)字互轉(zhuǎn)的實(shí)現(xiàn)

    這篇文章主要介紹了C/C++字符串與數(shù)字互轉(zhuǎn)的實(shí)現(xiàn),文中通過示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧
    2020-01-01
  • 帶你粗略了解c++的最大乘積

    帶你粗略了解c++的最大乘積

    這篇文章主要為大家詳細(xì)介紹了C++的最大乘積,具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下,希望能給你帶來幫助
    2021-08-08

最新評(píng)論