python树的双亲存储结构的实现示例

 更新时间:2023年11月24日 11:49:04   作者:Guff_hys  
本文主要介绍了python树的双亲存储结构,这种存储结构是一种顺序存储结构,采用元素形如“[结点值,双亲结点索引]”的列表表示,感兴趣的可以了解一下

这种存储结构是一种顺序存储结构,采用元素形如“[结点值,双亲结点索引]”的列表表示。通常每个结点有唯一的索引(或者伪地址),根结点的索引为0,它没有双亲结点,其双亲结点的索引为-1。例如,所示的树对应的双亲存储结构如下:

树的双亲存储结构

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

在该存储结构t中,索引为i的结点是t[i],其中t[i][0]为结点值,t[i][1]为该结点的双亲结点的索引。

若一棵树采用双亲在储结构存储,设计一个算法求指定索引是i的结点的层次。

解:用cnt 表示索引i的结点的层次(初始为1)。沿着双亲指针向上移动,当没有到达根结点时循环:cnt 增1,i向上移动一次。当到达根结点时cnt 恰好为原索引i结点的层次,最后返回cnt。对应的算法如下:

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

 python树的双亲存储结构:

class FNode():
    def __init__(self,name=None,i=None):#name为数据,i为其对应的父节点下标
        self.node=[name,i]
class ftree():#存储节点数据
    def __init__(self):
        self.data=[]
    #增加
    def add(self,name,i):#添加节点数据进入数的结构
        p = FNode(name,i)#建立节点
        self.data.append(p.node)#添加进入
    #创建
    def CreateTree(self,arr):#传入对应数据建立数arr为一个树关系的二维列表
        for i in arr:
            self.data.append(i)
    #删除
    def Dex(self,name,i):#给出节点的name和i进行删除
        for j in range(len(self.data)):
            if self.data[j][0]==name and self.data[j][1]==i:
                self.data.pop(j)
                break
    # 修改节点数据
    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
    #查找节点
    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]

    #遍历树结构,双亲存储单位的结构决定了它只能层次遍历
    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))

双亲存储结构利用了每个结点(根节点除外)有啡一双亲的性质。在这种存储结构中,求某个结点的双亲结点十分容易,但求某个结点的孩子结点时需要遍历整个结构。

到此这篇关于python树的双亲存储结构的文章就介绍到这了,更多相关python树的双亲存储结构内容请搜索脚本之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持脚本之家!

相关文章

  • 使用Python判断质数(素数)的简单方法讲解

    使用Python判断质数(素数)的简单方法讲解

    这篇文章主要介绍了使用Python判断质数(素数)的简单方法讲解,经常被用来做科学计算的Python处理这种小问题当然手到擒来^_-需要的朋友可以参考下
    2016-05-05
  • Tensor和NumPy相互转换的方法

    Tensor和NumPy相互转换的方法

    本文主要介绍了Tensor和NumPy相互转换的方法,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧
    2023-03-03
  • Python如何利用%操作符格式化字符串详解

    Python如何利用%操作符格式化字符串详解

    %是Python风格的字符串格式化操作符,非常类似C语言里的printf()函数的字符串格式化,下面这篇文章主要给大家介绍了关于Python如何利用%操作符格式化字符串的相关资料,需要的朋友可以参考下
    2021-10-10
  • 用Python制作在地图上模拟瘟疫扩散的Gif图

    用Python制作在地图上模拟瘟疫扩散的Gif图

    这篇文章主要介绍了如何用Python制作在地图上模拟瘟疫扩散的Gif图,其中用到了欧拉公式等数学知识、需要一定的算法基础,需要的朋友可以参考下
    2015-03-03
  • Python装饰器(decorator)定义与用法详解

    Python装饰器(decorator)定义与用法详解

    这篇文章主要介绍了Python装饰器(decorator)定义与用法,结合具体实例形式详细分析了Python装饰器的概念、功能及相关使用技巧,需要的朋友可以参考下
    2018-02-02
  • Python实现对word文档添加密码去除密码的示例代码

    Python实现对word文档添加密码去除密码的示例代码

    这篇文章主要介绍了Python实现对word文档添加密码去除密码,本文通过实例代码给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友可以参考下
    2020-12-12
  • Python读取Excel数据并进行可视化分析

    Python读取Excel数据并进行可视化分析

    这篇文章主要为大家详细介绍了如何使用Python实现读取Excel数据并进行可视化分析,文中的示例代码讲解详细,感兴趣的小伙伴可以了解一下
    2025-08-08
  • python在控制台输出进度条的方法

    python在控制台输出进度条的方法

    这篇文章主要介绍了python在控制台输出进度条的方法,实例分析了Python输出进度条效果的方法,需要的朋友可以参考下
    2015-06-06
  • Centos Python2 升级到Python3的简单实现

    Centos Python2 升级到Python3的简单实现

    下面小编就为大家带来一篇Centos Python2 升级到Python3的简单实现。小编觉得挺不错的,现在就分享给大家,也给大家做个参考。一起跟随小编过来看看吧
    2016-06-06
  • Python try-except-else-finally的具体使用

    Python try-except-else-finally的具体使用

    本文主要介绍了Python try-except-else-finally的具体使用,文中通过示例代码介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
    2021-08-08

最新评论