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

python樹的雙親存儲(chǔ)結(jié)構(gòu)的實(shí)現(xiàn)示例

 更新時(shí)間:2023年11月24日 11:49:04   作者:Guff_hys  
本文主要介紹了python樹的雙親存儲(chǔ)結(jié)構(gòu),這種存儲(chǔ)結(jié)構(gòu)是一種順序存儲(chǔ)結(jié)構(gòu),采用元素形如“[結(jié)點(diǎn)值,雙親結(jié)點(diǎn)索引]”的列表表示,感興趣的可以了解一下

這種存儲(chǔ)結(jié)構(gòu)是一種順序存儲(chǔ)結(jié)構(gòu),采用元素形如“[結(jié)點(diǎn)值,雙親結(jié)點(diǎn)索引]”的列表表示。通常每個(gè)結(jié)點(diǎn)有唯一的索引(或者偽地址),根結(jié)點(diǎn)的索引為0,它沒(méi)有雙親結(jié)點(diǎn),其雙親結(jié)點(diǎn)的索引為-1。例如,所示的樹對(duì)應(yīng)的雙親存儲(chǔ)結(jié)構(gòu)如下:

樹的雙親存儲(chǔ)結(jié)構(gòu)

t=[["A",-1],["B",0],["C",0],["D",1],["E",1],["F",1],["G",4]]

在該存儲(chǔ)結(jié)構(gòu)t中,索引為i的結(jié)點(diǎn)是t[i],其中t[i][0]為結(jié)點(diǎn)值,t[i][1]為該結(jié)點(diǎn)的雙親結(jié)點(diǎn)的索引。

若一棵樹采用雙親在儲(chǔ)結(jié)構(gòu)存儲(chǔ),設(shè)計(jì)一個(gè)算法求指定索引是i的結(jié)點(diǎn)的層次。

解:用cnt 表示索引i的結(jié)點(diǎn)的層次(初始為1)。沿著雙親指針向上移動(dòng),當(dāng)沒(méi)有到達(dá)根結(jié)點(diǎn)時(shí)循環(huán):cnt 增1,i向上移動(dòng)一次。當(dāng)?shù)竭_(dá)根結(jié)點(diǎn)時(shí)cnt 恰好為原索引i結(jié)點(diǎn)的層次,最后返回cnt。對(duì)應(yīng)的算法如下:

def find_level(parent, i):
    cnt = 1
    while parent[i] != -1:
        cnt += 1
        i = parent[i]
    return cnt

 python樹的雙親存儲(chǔ)結(jié)構(gòu):

class FNode():
    def __init__(self,name=None,i=None):#name為數(shù)據(jù),i為其對(duì)應(yīng)的父節(jié)點(diǎn)下標(biāo)
        self.node=[name,i]
class ftree():#存儲(chǔ)節(jié)點(diǎn)數(shù)據(jù)
    def __init__(self):
        self.data=[]
    #增加
    def add(self,name,i):#添加節(jié)點(diǎn)數(shù)據(jù)進(jìn)入數(shù)的結(jié)構(gòu)
        p = FNode(name,i)#建立節(jié)點(diǎn)
        self.data.append(p.node)#添加進(jìn)入
    #創(chuàng)建
    def CreateTree(self,arr):#傳入對(duì)應(yīng)數(shù)據(jù)建立數(shù)arr為一個(gè)樹關(guān)系的二維列表
        for i in arr:
            self.data.append(i)
    #刪除
    def Dex(self,name,i):#給出節(jié)點(diǎn)的name和i進(jìn)行刪除
        for j in range(len(self.data)):
            if self.data[j][0]==name and self.data[j][1]==i:
                self.data.pop(j)
                break
    # 修改節(jié)點(diǎn)數(shù)據(jù)
    def alter(self,name,i,n_name):
        for j in range(len(self.data)):
            if self.data[j][0]==name and self.data[j][1]==i:
                self.data[j][0]=n_name
                break
    #查找節(jié)點(diǎn)
    def find(self,name,i):
        for j in range(len(self.data)):
            if self.data[j][0]==name and self.data[j][1]==i:
                return self.data[j]

    #遍歷樹結(jié)構(gòu),雙親存儲(chǔ)單位的結(jié)構(gòu)決定了它只能層次遍歷
    def display(self):
        for i in range(len(self.data)):
            print(self.data[i][0],end=" ")
        print()

t = [['A',-1],['B',0],['C',0],['D',1],['E',1],['F',1],['G',4]]
tree_1 = ftree()
tree_1.CreateTree(t)
tree_1.display()
tree_1.add('H',4)
tree_1.display()
tree_1.Dex('H',4)
tree_1.display()
tree_1.alter('G',4,'5')
tree_1.display()
print(tree_1.find('A',-1))

雙親存儲(chǔ)結(jié)構(gòu)利用了每個(gè)結(jié)點(diǎn)(根節(jié)點(diǎn)除外)有啡一雙親的性質(zhì)。在這種存儲(chǔ)結(jié)構(gòu)中,求某個(gè)結(jié)點(diǎn)的雙親結(jié)點(diǎn)十分容易,但求某個(gè)結(jié)點(diǎn)的孩子結(jié)點(diǎn)時(shí)需要遍歷整個(gè)結(jié)構(gòu)。

到此這篇關(guān)于python樹的雙親存儲(chǔ)結(jié)構(gòu)的文章就介紹到這了,更多相關(guān)python樹的雙親存儲(chǔ)結(jié)構(gòu)內(nèi)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!

相關(guān)文章

最新評(píng)論