Python二叉搜索树与双向链表转换实现方法
作者:阿涵-_- 发布时间:2022-08-23 12:46:34
标签:Python,二叉搜索树,双向链表
本文实例讲述了Python二叉搜索树与双向链表实现方法。分享给大家供大家参考,具体如下:
# encoding=utf8
'''
题目:输入一棵二叉搜索树,将该二叉搜索树转换成一个排序的双向链表。
要求不能创建任何新的结点,只能调整树中结点指针的指向。
'''
class BinaryTreeNode():
def __init__(self, value, left = None, right = None):
self.value = value
self.left = left
self.right = right
def create_a_tree():
node_4 = BinaryTreeNode(4)
node_8 = BinaryTreeNode(8)
node_6 = BinaryTreeNode(6, node_4, node_8)
node_12 = BinaryTreeNode(12)
node_16 = BinaryTreeNode(16)
node_14 = BinaryTreeNode(14, node_12, node_16)
node_10 = BinaryTreeNode(10, node_6, node_14)
return node_10
def print_a_tree(root):
if root is None:return
print_a_tree(root.left)
print root.value, ' ',
print_a_tree(root.right)
def print_a_linked_list(head):
print 'linked_list:'
while head is not None:
print head.value, ' ',
head = head.right
print ''
def create_linked_list(root):
'''构造树的双向链表,返回这个双向链表的最左结点和最右结点的指针'''
if root is None:
return (None, None)
# 递归构造出左子树的双向链表
(l_1, r_1) = create_linked_list(root.left)
left_most = l_1 if l_1 is not None else root
(l_2, r_2) = create_linked_list(root.right)
right_most = r_2 if r_2 is not None else root
# 将整理好的左右子树和root连接起来
root.left = r_1
if r_1 is not None:r_1.right = root
root.right = l_2
if l_2 is not None:l_2.left = root
# 由于是双向链表,返回给上层最左边的结点和最右边的结点指针
return (left_most, right_most)
if __name__ == '__main__':
tree_1 = create_a_tree()
print_a_tree(tree_1)
(left_most, right_most) = create_linked_list(tree_1)
print_a_linked_list(left_most)
pass
希望本文所述对大家Python程序设计有所帮助。


猜你喜欢
- 读取数据(Reading data)TensorFlow输入数据的方式有四种:tf.data API:可以很容易的构建一个复杂的输入通道(p
- 在Perfection kills上看到他去年写的一篇文章,关于HTML优化的,讲的很详细,姑且记录之,尽管里面有些东西并不能在目前的环境里
- 一、现象最近在数据库中删除了一张表,重新执行python manage.py migrate时出错,提示不存在这张表。通过查找相关的资料,最
- 在开始聊我在阿里四个月的网页推广设计之前,我想先来说说我对平面设计和网页设计的认识。它们之间的交集。它们都是集艺术创作、电脑技术和数字技术于
- 摘要在机器视觉中,对于图像的处理有时候因为放置的原因导致ROI区域倾斜,这个时候我们会想办法把它纠正为正确的角度视角来,方便下一步的布局分析
- 什么是进程进程就是操作系统中执行的一个程序,操作系统以进程为单位分配存储空间,每个进程都有自己的地址空间、数据栈以及其他用于跟踪进程执行的辅
- 快速测试创建项目与appdjango-admin startproject mysitedjango-admin startapp app1
- 在平时的工作中,难免需要一些 小Tip 来解决工作中遇到的问题,今天的文章给大家安利一个方便快捷的小技巧,将 Office(doc/docx
- 使用torchvision库的datasets类加载常用的数据集或自定义数据集图像识别是计算机视觉中的一个基础任务,它的目标是让计算机能够识
- 让我们首先考虑正方形和长方形。如果我们认为在接口方面,忽略了实现细节,方块是否是矩形的子类型?子类型的定义取决于Liskov代换原理。为了成
- 1 插件安装想要在vscode中使用jupyter,首先我们需要在vscode中安装插件Jupyter。在拓展中搜索jupyter直接安装即
- 最近在处理词向量这块,因为平时习惯把处理的词向量保存成文件,但是txt文件读取出来的都是string格式的数字,有必要转成float型上网查
- 1. Min.us: 上传图片的最简单方任何开发人员、设计师、网络管理员都必须跟客户和同事在线分享图片。Min.us的全部服务就是让你极度简
- 前言昨天,因为项目需求要添加表的更新接口,来存储预测模型训练的数据,所以自己写了一段代码实现了该功能,在开始之前,给大家分享python 操
- 摘要: 前端框架 Bootstrap 的模态对话框,可以使用 remote 选项指定一个 URL,这样对话框在第一次弹出的时候就会自动从这个
- 如下所示:# -*- coding:utf-8 -*-class Solution: # matrix类型为二维列表,需要返回列
- 操作 redisimport redisredisPool = redis.ConnectionPool(host='192.168
- JS添加/删除事件在IE和支持dom浏览器分别为:attachEvent(ie中的添加事件),detachEvent(ie中的删除事件),a
- MySQL是一个小巧玲珑但功能强大的数据库,目前十分流行。但是官网给出的安装包有两种格式,一个是msi格式,一个是zip格式的。很多人下了z
- 在机器学习过程中,通常会通过pandas读取csv文件,保持成dadaframe格式,然而有时候需要对dataframe中的时间字段进行数据