0
  • 聊天消息
  • 系統(tǒng)消息
  • 評論與回復
登錄后你可以
  • 下載海量資料
  • 學習在線課程
  • 觀看技術視頻
  • 寫文章/發(fā)帖/加入社區(qū)
會員中心
創(chuàng)作中心

完善資料讓更多小伙伴認識你,還能領取20積分哦,立即完善>

3天內不再提示

樹的遞歸結構和樹的存儲結構分析

454398 ? 來源:機器之心 ? 作者:小小 ? 2020-10-16 14:33 ? 次閱讀

樹的遞歸結構

從一張圖中解釋什么是樹

這張圖,主要講解關于cart這個單詞的所有的可能組合,按照常理,需要先考慮三個字母的排列,然后對三個字母進行拆分,直到最后一個節(jié)點,這個過程就類似于樹 到底什么是樹

什么是樹

樹是節(jié)點集合(A tree is a collection of nodes),

集合:集合是允許一個元素都沒有的集合,稱之為空集。

首先,集合是允許一個元素都沒有的集合,稱之為空集,那么書是不是也允許一個節(jié)點都沒有的呢,是的,一個節(jié)點都沒有的樹,稱之為空樹,如果不是空的,則會存在根節(jié)點r和零個或更多非空子樹,T1,T2.。。Tk,他們的根由來自r的有向連接,什么叫有向邊,大致可以理解為箭頭。用圖的關系說明樹的內部關系

根節(jié)點(root)一棵樹只有一個跟節(jié)點,所有的節(jié)點都在該節(jié)點的下面,嘗試把圖倒過來看,可以看成一個我們日常見到的數(shù)的根部,在這里顯然字母A就是這顆樹的根節(jié)點。

子節(jié)點,父節(jié)點,一個節(jié)點,它對應的下面有連這的節(jié)點,那么被連著的節(jié)點就是這個節(jié)點的子節(jié)點,也叫做孩子,那么這個節(jié)點叫做被連接的節(jié)點的父親,看圖,B被A連這,所以B是A的一個孩子,同理,CDE等等這一行都是A的孩子,同時F,它連這K L M 同時被A連這,那么F是A的一個孩子,同時又是K L M 的父親。

樹葉:樹葉就是那些沒有孩子的節(jié)點,比如B,C,D等等,例如下圖的綠色部分。

兄弟: 按照我們的理解,同一個父母生的當然是兄妹,如下圖所示,顏色相同的都是兄妹

路徑 我們同樣可以定義從父親到他孩子的路徑,下面的路徑,我們就取上圖的一部分,一個子樹,作為例子

比如,A->O的路徑為A->E->J->O它的長度為3,實際為它的邊數(shù),圖中紅色的部分。

節(jié)點的深度:節(jié)點的深度指的是節(jié)點到樹根的長度,看下圖,我們可以輕易的知道,j節(jié)點的深度為2,可以理解為 A-> E -> J 邊長為2.顯然,此時根節(jié)點的深度為0.

節(jié)點的高度:高度是從節(jié)點到葉子的最長路徑,比如節(jié)點F的高度為1,顯然所有葉子節(jié)點高度為0.

樹的高度,樹的高度是跟的高度,顯然在這圖中,樹的高度為3,A->O

樹的特點

按照正常的邏輯,一個人不能同時有兩個父親,所以樹也一樣,下圖的兩個就解釋了這個問題

一顆正常的樹,它的樹枝是不會長成一個圓的,所以,樹中,是不可能出現(xiàn)環(huán)形的。圖中,紅色箭頭構成了一個環(huán),所以都不是一顆樹。

樹的存儲結構

樹的存儲結構有三種,分別為,雙親表示法,孩子表示法,孩子兄弟表示法。

雙親表示法

假設一組連續(xù)空間保存著樹的特點,同時在每個節(jié)點中,附帶一個指示器表示雙親節(jié)點中鏈表的為位置,也就是說,每個節(jié)點除了知道自己是誰以外,還知道他的雙親在哪里。

其中data是數(shù)據(jù)域,存儲結點的數(shù)據(jù)信息。而parent是指針域,存儲該結點的雙親在數(shù)組中的下標。

//樹的雙親表示法結點結構定義
#define MAX_TRUE_SIZE 100
typedef int TElemType //樹結點的數(shù)據(jù)類型

//結點結構
typedef struct PTNode   
{
	TElemType data;  //結點數(shù)據(jù)
	int parent;   	//雙親位置
}PTNode

//樹結構
typedef struct
{
	PTNode nodes[MAX_TRUE_SIZE];  //結點數(shù)組
	int r,n     //根的位置和結點數(shù)
}PTree

有了這樣的數(shù)據(jù)結構就可以來實現(xiàn)雙親表示法。由于根結點是沒有雙親的,所以我們約定根結點的位置域設置為-1,這也就意味著,我們所有的結點都存有他雙親的位置。如圖1-2中的樹結構和表1-3中的樹雙親表示。

這樣的存儲結構,我們可以根據(jù)結點的parent’指針很容易找到他的雙親結點,時間復雜度為O(1),直到parent為-1時,表示找到了樹結點的根

孩子表示法

換一種完全不同的考慮方法,由于樹中每個結點可能有多棵子樹,可以考慮用多重鏈表。每個結點有多個指針域,其中每個指針指向一顆子樹的根結點,我們把這種方法叫做多重鏈表的表示方法。不過,樹的每個結點的度,也就是他的孩子個數(shù)是不同的,所以設計兩種方法:

方案一

指針域的個數(shù)就等于樹的度,樹的度就是樹各個結點度的最大值。其結構如圖

其中data是數(shù)據(jù)域,child1到childd是指針域,用來指向該結點的孩子結點。對于圖1-1來說,樹的度是3,所以我們指針域個數(shù)就是3,

方案二

每個結點指針域的個數(shù)等于該結點的度,我們專門取一個位置來存儲結點指針的個數(shù)。

data為指針域,degree為度域,也就是存儲該結點的孩子結點的個數(shù)

這就是我們要說的孩子表示法,把每個結點的孩子都排列起來,以單鏈表為存儲結構,則n個結點有n個孩子鏈表,如果是葉子結點則此單鏈表為空。然后n個頭指針又組成一個線性表,采用順序存儲結構,存放進一個一維數(shù)組,

為此,設計兩種存儲結構,一個是孩子鏈表的孩子結點,

child是數(shù)據(jù)域,用來存儲某個結點在表頭數(shù)組中的下標。next是指針域,用來存儲指向結點的下一個孩子結點的指針。另一個是表頭數(shù)組的表頭結點。

data是數(shù)據(jù)域,存儲某結點的數(shù)據(jù)信息,firstchild是頭指針域,存儲該結點的孩子鏈表的頭指針。

//樹的孩子表示法結構定義
#define MAX_TRUE_SIZE 100
typedef struct CTNode  //孩子結點
{
	int child;
	struct CTNode *next;
}*ChildPtr;
//表頭結構
typedef struct
{
	TElemType data;
	ChildPtr firstchild;
}CTBox;
//樹結構
typedef struct
{
	CTBox nodes[MAX_TRUE_SIZE];  //結點數(shù)組
	int r,n;               //根的位置和結點數(shù)
}CTree

把把雙親表示法和孩子表示法綜合一下表示如下

這種表示法叫做雙親孩子表示法,應該算是孩子表示法的改進。

孩子兄弟表示法

任一棵樹,它的結點的第一個孩子如果存在就是唯一的,它的右兄弟如果存在也是唯一的。因此。我們設置兩個指針,分別指向該結點的第一個孩子和此結點的右兄弟。

data是數(shù)據(jù)域,fitstchild為指針域,存儲該結點的第一個孩子結點的存儲地址,rightsib是指針域,存儲該結點的右兄弟結點的存儲位置。

//孩子兄弟表示法結構定義
typedef struct CSDNode
{
	TElemType data;
	struct CSNode *firstchild,*rightsib;
}CSNode,*CSTree;

這種方法的示意圖如下所示

這種表示法,給查找某個結點的某個孩子帶來了方便,只需要通過firstchild找到此結點的長子,然后在通過長子結點的rightsib找到它的二弟,接著一直找下去,直到找到具體的孩子。
編輯:hfy

聲明:本文內容及配圖由入駐作者撰寫或者入駐合作網(wǎng)站授權轉載。文章觀點僅代表作者本人,不代表電子發(fā)燒友網(wǎng)立場。文章及其配圖僅供工程師學習之用,如有內容侵權或者其他違規(guī)問題,請聯(lián)系本站處理。 舉報投訴
收藏 人收藏

    評論

    相關推薦

    什么是默克爾(Merkle Tree)?如何計算默克爾根?

    01 默克爾的概念 默克爾(Merkle Tree)是一種特殊的二叉,它的每個節(jié)點都存儲了一個數(shù)據(jù)塊的哈希值。哈希值是一種可以將任意長度的數(shù)據(jù)轉換為固定長度的字符串的算法,它具有
    的頭像 發(fā)表于 09-30 18:22 ?481次閱讀
    什么是默克爾<b class='flag-5'>樹</b>(Merkle Tree)?如何計算默克爾根?

    遞歸神經(jīng)網(wǎng)絡和循環(huán)神經(jīng)網(wǎng)絡的模型結構

    遞歸神經(jīng)網(wǎng)絡是一種旨在處理分層結構的神經(jīng)網(wǎng)絡,使其特別適合涉及樹狀或嵌套數(shù)據(jù)的任務。這些網(wǎng)絡明確地模擬了層次結構中的關系和依賴關系,例如語言中的句法結構或圖像中的層次表示。它使用
    的頭像 發(fā)表于 07-10 17:21 ?492次閱讀
    <b class='flag-5'>遞歸</b>神經(jīng)網(wǎng)絡和循環(huán)神經(jīng)網(wǎng)絡的模型<b class='flag-5'>結構</b>

    遞歸神經(jīng)網(wǎng)絡的實現(xiàn)方法

    (Recurrent Neural Network,通常也簡稱為RNN,但在此處為區(qū)分,我們將循環(huán)神經(jīng)網(wǎng)絡稱為Recurrent RNN)不同,遞歸神經(jīng)網(wǎng)絡更側重于處理樹狀或圖結構的數(shù)據(jù),如句法分析樹、自然語言的語法
    的頭像 發(fā)表于 07-10 17:02 ?261次閱讀

    遞歸神經(jīng)網(wǎng)絡結構形式主要分為

    結構形式。 Elman網(wǎng)絡 Elman網(wǎng)絡是一種基本的遞歸神經(jīng)網(wǎng)絡結構,由Elman于1990年提出。其結構主要包括輸入層、隱藏層和輸出層,其中隱藏層具有時間延遲單元,可以
    的頭像 發(fā)表于 07-05 09:32 ?435次閱讀

    遞歸神經(jīng)網(wǎng)絡的結構、特點、優(yōu)缺點及適用場景

    識別、時間序列分析等領域有著廣泛的應用。本文將詳細介紹遞歸神經(jīng)網(wǎng)絡的結構、特點、優(yōu)缺點以及適用場景。 一、遞歸神經(jīng)網(wǎng)絡的結構 基本
    的頭像 發(fā)表于 07-04 14:52 ?992次閱讀

    原理圖設計里兩顆重要的(國產EDA)

    原理圖里面兩顆重要的,那就是元件和網(wǎng)絡,作為EDA工具中的重要視圖和概念,雖然看似枯燥,但它們扮演著非常重要的角色,它們?yōu)殡娐穲D的層次化結構提供了有力支撐。想象一個大型的電路設計
    的頭像 發(fā)表于 05-29 17:47 ?646次閱讀
    原理圖設計里兩顆重要的<b class='flag-5'>樹</b>(國產EDA)

    MCP251X can驅動移植nuc980采樣用設備配置時,中斷如何配置設備?

    MCP251X can驅動移植nuc980 采樣用設備配置時,中斷如何配置設備? spi0: spi@b0061000 { status = \"okay\"
    發(fā)表于 01-17 06:43

    如何修改內核設備

    如何修改內核設備
    的頭像 發(fā)表于 12-14 14:06 ?750次閱讀
    如何修改內核設備<b class='flag-5'>樹</b>

    如何修改內核設備

    本文檔介紹了內核設備的位置和包含關系 1.內核設備位置 文件 備注 dts longan/device/config/chips/t507/configs/evb/board.dts
    發(fā)表于 12-14 13:42

    決策:技術全解與案例實戰(zhàn)

    決策算法是機器學習領域的基石之一,其強大的數(shù)據(jù)分割能力讓它在各種預測和分類問題中扮演著重要的角色。
    的頭像 發(fā)表于 12-13 09:49 ?1155次閱讀
    決策<b class='flag-5'>樹</b>:技術全解與案例實戰(zhàn)

    時鐘是什么?介紹兩種時鐘樹結構

    今天來聊一聊時鐘。首先我先講一下我所理解的時鐘是什么,然后介紹兩種時鐘樹結構。
    的頭像 發(fā)表于 12-06 15:23 ?1559次閱讀

    數(shù)字IC設計中的分段時鐘綜合

    為什么需要分段去做時鐘呢?因為在某些情況下,按照傳統(tǒng)的方法讓每一個clock group單獨去balance,如果不做額外干預,時鐘天然是做不平的。
    的頭像 發(fā)表于 12-04 14:42 ?1769次閱讀
    數(shù)字IC設計中的分段時鐘<b class='flag-5'>樹</b>綜合

    【米爾-TIAM62開發(fā)板-接替335x-試用評測】+(三)手把手創(chuàng)建Uboot設備與內核設備實戰(zhàn)

    ,我研究了設備的層級結構。在U-Boot中,設備文件通常包括一個主設備文件和其他一些子設備文件。這些文件描述了各種硬件設備的配置信息
    發(fā)表于 11-28 09:54

    與二叉的定義

    結構 是一類重要的 非線性數(shù)據(jù)結構 ,其中以和二叉最為常用,直觀來看,是以分支關系定義
    的頭像 發(fā)表于 11-24 15:57 ?1247次閱讀
    <b class='flag-5'>樹</b>與二叉<b class='flag-5'>樹</b>的定義

    大型多GHz時鐘中的相位偏差設計

    電子發(fā)燒友網(wǎng)站提供《大型多GHz時鐘中的相位偏差設計.pdf》資料免費下載
    發(fā)表于 11-22 16:56 ?0次下載
    大型多GHz時鐘<b class='flag-5'>樹</b>中的相位偏差設計