二叉搜索树与python中self参数理解
时间:2022-07-28
本文章向大家介绍二叉搜索树与python中self参数理解,主要内容包括其使用实例、应用技巧、基本知识点总结和需要注意事项,具有一定的参考价值,需要的朋友可以参考一下。
⭐️⭐️
1
题目描述
今天刷的是LeetCode的530题:给定一个节点值均为非负的二叉搜索树,求任意两节点差的绝对值的最小值。
2
知识点
知识点一:二叉搜索树
二叉搜索树同时满足以下几个条件:
- 它是一颗空树或一颗二叉树
- 若它的左子树不空,则左子树上所有结点的值均小于它的根节点的值;若它的右子树不空,则右子树上所有结点的值均大于它的根结点的值。
并且,它的左、右子树也分别为二叉搜索树。
知识点二:python中的self理解
python中,用class来定义一个类,类中包含属性和调用方法,当创建一个该类的实例,这个实例也就拥有这个类的属性和调用方法。这里要注意以下几点:
- 调用方法的第一个参数为self。表示类的实例,也就是说明是对哪个主体进行相应的函数操作。调用时不用传递该参数。
- 在类中,方法相互调用要加 self。
结合题目中定义二叉树类的代码进行详细了解:
# Definition for a binary tree node.
# class TreeNode:
# def __init__(self, x):
# self.val = x
# self.left = None
# self.right = None
类TreeNode是表示二叉树的类,这个类中有一个__init__调用方法,第一个参数是self,方法中的意思就是针对该类的实例,设置val为x,left为None,right为None,其中val、left、right是类的属性。
3
题解
思路:中序遍历
中序遍历指先访问左子树,再访问根节点,最后访问右子树。根据二叉搜索树的特点,经过中序遍历后,得到一个递增的列表,并且根据题目要求,想要得到差的绝对值的最小值,则一定是从两个相邻的值相减得到的,因此对递增列表相邻值求差,就可得到最后结果。
# Definition for a binary tree node.
# class TreeNode:
# def __init__(self, x):
# self.val = x
# self.left = None
# self.right = None
class Solution:
def getMinimumDifference(self, root: TreeNode):
#中序遍历
nodeorder = []
def inorder(root):#这里不是类的方法,只是对一个参数通过函数进行计算
if root.left is not None:
inorder(root.left)
nodeorder.append(root.val)
if root.right is not None:
inorder(root.right)
inorder(root)
#求相邻两个数的差值
for i in range(0,len(nodeorder)-1):
nodeorder[i] = nodeorder[i+1]-nodeorder[i]
return min(nodeorder[0:-1])
- @ResponseBody响应JSON 406
- tomcat不能运行或共存多个项目
- Spring Task 定时任务
- 如何为机器学习索引,切片,调整 NumPy 数组
- 逆向工程分析:摩托罗拉安全摄像头究竟有多不安全?
- 【maven学习】 利用Profile构建不同环境的部署包
- 如何写好一份渗透测试报告?
- jqGrid 关闭刷新父页面数据
- [MyBatis]诡异的Invalid bound statement (not found)错误
- jfinal自定义freemarker标签
- Angrok 一个内网穿透服务
- Druid数据库连接池 实现数据库账号密码加密
- 【maven学习】划分模块
- 缓存策略优化
- JavaScript 教程
- JavaScript 编辑工具
- JavaScript 与HTML
- JavaScript 与Java
- JavaScript 数据结构
- JavaScript 基本数据类型
- JavaScript 特殊数据类型
- JavaScript 运算符
- JavaScript typeof 运算符
- JavaScript 表达式
- JavaScript 类型转换
- JavaScript 基本语法
- JavaScript 注释
- Javascript 基本处理流程
- Javascript 选择结构
- Javascript if 语句
- Javascript if 语句的嵌套
- Javascript switch 语句
- Javascript 循环结构
- Javascript 循环结构实例
- Javascript 跳转语句
- Javascript 控制语句总结
- Javascript 函数介绍
- Javascript 函数的定义
- Javascript 函数调用
- Javascript 几种特殊的函数
- JavaScript 内置函数简介
- Javascript eval() 函数
- Javascript isFinite() 函数
- Javascript isNaN() 函数
- parseInt() 与 parseFloat()
- escape() 与 unescape()
- Javascript 字符串介绍
- Javascript length属性
- javascript 字符串函数
- Javascript 日期对象简介
- Javascript 日期对象用途
- Date 对象属性和方法
- Javascript 数组是什么
- Javascript 创建数组
- Javascript 数组赋值与取值
- Javascript 数组属性和方法