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

C語言線索二叉樹基礎(chǔ)解讀

 更新時間:2022年04月25日 17:10:29   作者:洛語言  
線索二叉樹還是按照鏈二叉樹的方法創(chuàng)建,只不過在結(jié)點原本為空的左指針改為指向該結(jié)點在中序遍歷中的前驅(qū),結(jié)點原本為空的右指針改為指向該結(jié)點在中序遍歷中的后繼,也就是說把空的指針給利用了起來

線索二叉樹的意義

  • 對于一個有n個節(jié)點的二叉樹,每個節(jié)點有指向左右孩子的指針域。其中會出現(xiàn)n+ 1個空指針域,這些空間不儲存任何事物,浪費著內(nèi)存的資源。
  • 對于一些需要頻繁進(jìn)行二叉樹遍歷操作的場合,二叉樹的非遞歸遍歷操作過程相對比較復(fù)雜,遞歸遍歷雖然簡單明了,但是會有額外的開銷,對于操作的時間和空間都比較浪費。
  • 我們可以考慮利用這些空地址,存放指向節(jié)點在某種遍歷次序下的前驅(qū)和后繼節(jié)點的地址。通過這些前驅(qū)和后繼節(jié)點的地址可以知道,從當(dāng)前位置下一步應(yīng)該走向哪里。

線索二叉樹的定義

  • 指向前驅(qū)和后繼的指針稱為線索,加上線索的二叉鏈表稱為線索鏈表,相應(yīng)的二叉樹就稱為線索二叉樹。
  • 對二叉樹以某種次序遍歷使其變?yōu)榫€索二叉樹的過程稱為線索化。

線索二叉樹結(jié)構(gòu)的實現(xiàn)

二叉樹的線索存儲結(jié)構(gòu)

為了區(qū)分二叉樹某一節(jié)點是指向它的孩子節(jié)點還是指向前驅(qū)或者后繼節(jié)點,我們可以在每個節(jié)點增設(shè)兩個標(biāo)志,Ltag,Rtag.

其中:

  • Ltag為0時,代表該節(jié)點指向它的左孩子,Ltag為1時,代表該節(jié)點指向它的前驅(qū)節(jié)點。
  • Rtag為0時,代表該節(jié)點指向它的右孩子,Rtag為1時,代表該節(jié)點指向它的后繼節(jié)點。

所以,線索二叉樹結(jié)構(gòu)定義代碼如下:

typedef char BTDataType;
typedef enum{Link,Thread}PointerTag;//Link 是0,Thread 是1。
typedef struct BinaryTreeNode
{
	struct BinaryTreeNode* left;
	struct BinaryTreeNode* right;
	PointerTag LTag ;
	PointerTag RTag;
	BTDataType data;
}BTNode;

二叉樹的中序線索化

線索化的過程就是在遍歷過程中修改空指針的過程

以上二叉樹中序遍歷可以得到:

  D B E A F C
  D的前驅(qū)是空,后繼是B
  B的前驅(qū)是D,后繼是E
  E的前驅(qū)是B,后繼是A
  F的前驅(qū)是A,后繼是C
  C的前驅(qū)是F,后繼是空

線索化后:

中序遍歷線索化的遞歸函數(shù)代碼如下:

//中序線索化
BTNode* pre = NULL;/*全局變量,始終指向剛剛訪問過的節(jié)點*/
void InThreading(BTNode* p)
{
	if (p == NULL) return;
	InThreading(p->left);//遞歸左子樹線索化
	if (!p->left)//左孩子為空,left指針指向前驅(qū)
	{
		p->LTag = Thread;
		p->left = pre;
	}
	if (pre!=NULL && !pre->right)//右孩子為空,right指針指向后繼指針。
	//這里判斷 pre!=NULL 是因為線索化中序遍歷的第一個節(jié)點(節(jié)點D)時,它并沒有前驅(qū)節(jié)點,此時的pre仍然是NULL。
	{
		pre->RTag = Thread;
		pre->right = p;
	}
	pre = p;//保持pre指向p的前驅(qū)
	InThreading(p->right);
}

分析:

  • if (!p->left)表示如果某節(jié)點的左指針域為空,因為其前驅(qū)節(jié)點剛剛訪問過,并且賦值給了pre,所以可以將pre賦值給 l -> left,并且修改 p-> LTag = Thread,以完成前驅(qū)節(jié)點的線索化。
  • pre 是 p 的前驅(qū),那么, p 就是 pre 的后繼。當(dāng)pre -> right 為空時,就可以將p賦值給 pre -> right , 并且修改 pre -> RTag = Thread。

線索二叉樹的中序遍歷

void MidOrder(BTNode*p)
{
	while (p != NULL)
	{
		while (p->LTag == Link)//
		{
			p = p->left;
		}
		printf("%c ",p->data);
		while (p->RTag == Thread && p->right != p)
		{
			p = p->right;
			printf("%c ", p->data);
		}
		p = p->right;
	}
	return;
}

分析:

  • while (T->ltag == Link)從根節(jié)點開始遍歷,如果左標(biāo)記是Link讓它一直循環(huán)下去,直到找到標(biāo)記為Thread的的結(jié)點,也就是要遍歷的第一個結(jié)點,然后根據(jù)后驅(qū)指針找到后繼結(jié)點
  • 后面就是重復(fù)以上過程,直到遍歷完整個二叉數(shù)。

總結(jié)

如果所用的二叉數(shù)需要經(jīng)常遍歷或查找結(jié)點時需要某種遍歷序列中的前驅(qū)和后繼,那么采用線索二叉數(shù)是一個很好的選擇;

以上內(nèi)容參考于《大話數(shù)據(jù)結(jié)構(gòu)》。

到此這篇關(guān)于C語言線索二叉樹基礎(chǔ)解讀的文章就介紹到這了,更多相關(guān)C語言線索二叉樹內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!

相關(guān)文章

  • C++實現(xiàn)迷宮算法實例解析

    C++實現(xiàn)迷宮算法實例解析

    這篇文章主要介紹了C++實現(xiàn)迷宮算法實例解析,是一個比較經(jīng)典的C++算法,有一定的學(xué)習(xí)與借鑒價值,需要的朋友可以參考下
    2014-07-07
  • CrashRpt使用案例詳解

    CrashRpt使用案例詳解

    這篇文章主要介紹了CrashRpt使用案例詳解,本篇文章通過簡要的案例,講解了該項技術(shù)的了解與使用,以下就是詳細(xì)內(nèi)容,需要的朋友可以參考下
    2021-08-08
  • C++ 中 const和static readonly區(qū)別

    C++ 中 const和static readonly區(qū)別

    這篇文章主要介紹了C++ 中 const和static readonly區(qū)別的相關(guān)資料,需要的朋友可以參考下
    2017-05-05
  • C語言鏈表實現(xiàn)通訊錄系統(tǒng)課程設(shè)計

    C語言鏈表實現(xiàn)通訊錄系統(tǒng)課程設(shè)計

    這篇文章主要為大家詳細(xì)介紹了C語言鏈表實現(xiàn)通訊錄系統(tǒng)課程設(shè)計,文中示例代碼介紹的非常詳細(xì),具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2022-06-06
  • C語言 數(shù)據(jù)結(jié)構(gòu)堆排序順序存儲(升序)

    C語言 數(shù)據(jù)結(jié)構(gòu)堆排序順序存儲(升序)

    這篇文章主要介紹了C語言 數(shù)據(jù)結(jié)構(gòu)堆排序順序存儲(升序)的相關(guān)資料,需要的朋友可以參考下
    2017-05-05
  • C語言實現(xiàn)猜數(shù)字小游戲

    C語言實現(xiàn)猜數(shù)字小游戲

    這篇文章主要為大家詳細(xì)介紹了C語言實現(xiàn)猜數(shù)字小游戲,文中示例代碼介紹的非常詳細(xì),具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2019-11-11
  • C語言編程數(shù)據(jù)結(jié)構(gòu)基礎(chǔ)詳解小白篇

    C語言編程數(shù)據(jù)結(jié)構(gòu)基礎(chǔ)詳解小白篇

    這篇文章主要介紹了數(shù)據(jù)結(jié)構(gòu)的基礎(chǔ),非常適合初學(xué)數(shù)據(jù)結(jié)構(gòu)的小白,有需要的朋友可以借鑒參考下,希望可以有所幫助,祝大家多多進(jìn)步,早日升職加薪
    2021-09-09
  • C++解決大數(shù)組棧內(nèi)存不夠問題的方法分析

    C++解決大數(shù)組棧內(nèi)存不夠問題的方法分析

    這篇文章主要介紹了C++解決大數(shù)組棧內(nèi)存不夠問題的方法,結(jié)合實例形式對比分析了C++針對大數(shù)組棧內(nèi)存不足情況的常見解決方法及其優(yōu)缺點,具有一定參考借鑒價值,需要的朋友可以參考下
    2018-05-05
  • C語言運算符的重載詳解

    C語言運算符的重載詳解

    這篇文章主要為大家詳細(xì)介紹C語言運算符的重載,文中示例代碼介紹的非常詳細(xì),具有一定的參考價值,感興趣的小伙伴們可以參考一下,希望能夠給你帶來幫助
    2022-02-02
  • C++ map的簡單使用實現(xiàn)

    C++ map的簡單使用實現(xiàn)

    map是STL的一個關(guān)聯(lián)容器,它以<key,value>一對一的形式存儲,且map的內(nèi)部自建一個紅黑樹,使得其可以自動排序,本文就介紹一下C++ map的簡單使用,感興趣的可以了解一下
    2021-05-05

最新評論