《你也能看得懂的Python算法书》学习笔记(四)
在学习完哈希算法之后,我们开始学习深度优先遍历算法。深度优先遍历算法是经典的图论算法,从某个节点v出发开始搜索,不断搜索直到该节点的所有边都被遍历完。当节点v的所有边都被遍历以后,深度优先遍历算法需要回溯到v的前驱节点,来继续搜索这个前驱节点的其他边。
树形结构是使用深度优先遍历算法最普遍的一种数据结构,而二叉树作为一种特殊的树形结构,也被人们广泛使用。二叉树分为:空二叉树、满二叉树、完全二叉树(除了最后一层,每一层都是满的,并且最后一层的节点全部从左排序)、完美二叉树、平衡二叉树。
二叉树的节点代码如下:
class Node:def __init__(self,x):self.val = xself.left = Noneself.right = None
二叉树有三种遍历方式:先序遍历(DLR)、中序遍历(LDR)、后序遍历(LRD)
对于如图所示的二叉树,他们的遍历顺序为:
先序遍历:1-2-4-5-3-6-7
中序遍历:4-2-5-1-6-7-3
后序遍历:4-5-2-6-7-3-1
例题:如何抓住小偷
题目描述:小偷盯上了一个以二叉树为结构的别墅小区,每个二叉树的结点的数字代表着小偷可以从这个节点获取的不义之财。由于二叉树的结构,除了第一栋别墅,其余的每一栋别墅都与另外一栋源头别墅相连,因此小偷如果闯入两栋相连的别墅则会触发警报,而小偷想要获得最多的钱,因此只有判断出小偷的偷盗路线才能将其抓获。
解题思路:
因为小偷进入两栋相连的别墅会触发警报,例如他闯入第一层,那么就不能偷第二层的房子,可以选择偷第三、四层的房子。因此他在做每一个决定的时候都要统观全局。下图给出了他在一种结中可能的偷窃路线
那么我们如何判断他为了获取最大值而选择的偷窃路线呢? 我们可以将每一个节点附上两个值,因为小偷在每个节点只有两种选择,偷或者不偷。因此这两个值可以代表他在这个节点上偷可以得的钱数和在这个节点上放弃可以获得的钱数。
上图我们从最底层开始,此时偷或者不偷的都是确定的。如果偷则得到相对应的钱,如果不偷则为0。下面我们将继续上移一层。
此时我们对首先对2结点的情况进行分析。如果偷窃,则可以获得4万元,但就无缘4、5节点的钱;而如果不偷,则会获得4、5节点的钱(1+3=4万元),但无缘2节点的钱。再对三节点进行分析,如果偷窃,则获得5万元;不偷窃则获得节点6的1万元。
此时我们继续上移,根据对根节点的判断得出,小偷应该不会偷根节点,这样才有可能取得最大数值。因此就只剩下了两种情况:
在以上的节点中我们可以得出一个规律:每一个节点的偷值都是:左节点的不偷值+右节点的不偷值+本节点的财富值;每一个节点的不偷值都是:左节点的最大值(max(偷,不偷))+右节点的最大值。
代码如下:
class TreeNode: # 定义节点类def __init__(self, x, left=None, right=None):self.val = xself.left = leftself.right = rightdef rob(self, root):a = self.helper(root)return max(a[0], a[1])def helper(self, root):if (root == None):return [0, 0]left = self.helper(root.left)right = self.helper(root.right)robValue = root.val + left[1] + right[1]skipValue = max(left[0], left[1]) + max(right[0], right[1])return [robValue, skipValue]
《你也能看得懂的Python算法书》学习笔记(四)相关推荐
- 你也能看得懂的python算法书pdf_你也能看得懂的Python算法书最新章节_王硕著_掌阅小说网...
1.2 三大结构 Python语言中有三大结构:循序.分支和循环.这三种结构分别适用于不同的情况,一个复杂的程序中常常同时包含这三种结构. 1.2.1 循序结构 说到"循序"这个词 ...
- 《假如编程是魔法之零基础看得懂的Python入门教程 》——(四)了解魔法百宝箱列表、字典及基本数据类型
学习目标 了解魔法世界中可更改容器--变量 了解魔法世界的基本数值类型--字符串.整数 了解魔法百宝箱--字典.列表 了解列表如何添加值 了解字典如何添加值 了解字典与列表定义的不同符号 目录 第一篇 ...
- 【Python 跟书学习笔记】
本文为个人从<Head First Python>中的学习笔记 目录 1. 基础知识 Python 数据结构 了解IDLE窗口 函数.模块.标准库 代码组 根据条件生成结果--if els ...
- python算法书籍-你也能看得懂的Python算法书
第1章 编程基础1 1.1 变量1 1.1.1 输出和输入2 1.1.2 简单变量类型3 1.1.3 数学计算6 1.1.4 位运算7 1.1.5 使用字符串11 1.2 三大结构15 1.2.1 循 ...
- python算法书推荐-你也能看得懂的Python算法书
第1章 编程基础1 1.1 变量1 1.1.1 输出和输入2 1.1.2 简单变量类型3 1.1.3 数学计算6 1.1.4 位运算7 1.1.5 使用字符串11 1.2 三大结构15 1.2.1 循 ...
- Python计算机视觉编程学习笔记 四 照相机模型与增强现实
照相机模型与增强现实 (一)针孔照相机模型 1.1 照相机模型 1.2 三维点的投影 1.3照相机矩阵的分解 1.4 计算照相机中心 (二)照相机标定 (三)以平面和标记物进行姿态估计 (四)增强现实 ...
- 编程小白的第一本Python入门书学习笔记 Charper6: 数据结构
目录 数据与结构 列表(`list`) 列表的增改删查 字典(`Dictionary`) 字典中的增改删查 元组(`Tuple`) 集合(`Set`) 数据结构中的一些技巧 多重循环 列表推导式 循环 ...
- Acwing算法基础课学习笔记(四)--数据结构之单链表双链表模拟栈模拟队列单调栈单调队列KMP
单链表 算法题中最常考的单链表就是邻接表(用来存储图和数),比如最短路问题,最小生成树问题,最大流问题.双链表用于优化某些问题. 利用数组来表达单链表:存储值和指针的两个数组利用下标进行关联. 需要注 ...
- 编程小白的第一本Python入门书学习笔记 Chapter4: 函数
目录 函数的创建 练习题 位置参数与关键词参数 易混淆点:参数名与变量名 默认参数 设计自己的函数 # 伪代码 def function (arg1, arg2):return result def ...
最新文章
- 基于 U-Net 的医学影像分割算法综述
- mysql sqlstate 28000_mysql ERROR 1045 (28000): 错误解决办法
- 剑指 Offer 61. 扑克牌中的顺子
- oracle clob 存储大于4000字符的字符串
- 挺好用的SQLSERVER数据库自动备份工具SQLBackupAndFTP(功能全面)
- jenkins通过Execute shell中通过scp/ssh命令,将一台机器中项目远程拷贝到另外一台机器,修改文件中内容
- 重写toString()方法(Java篇)
- 【Codeforces #130 Div2】Solutions
- Django REST FRAMEWORK swagger(一)框架详解
- pfring(pf_ring)编译安装
- Ant学习---第二节:Ant添加文件夹和文件夹集的使用
- HDU-1716 排列2 组合数
- 厉害了网页扫码,所有方法都给你总结到这了,赶紧收藏
- IELTS-writing exercise Expository_Text_18
- 入网认证遇到的安全受控机制的问题---之Android 5.1.1 AppOps与严格模式
- 记录几个程序员接单搞副业的网站
- onlyoffice5.4.2离线包的制作—解决中文字体问题
- linux可用直播软件,免费直播软件OBS Studio下载 支持Windows/Mac和Linux
- zip格式压缩文件并打包下载
- AT88SC0104C读写程序