refactor: Replace 结点 with 节点 (#452)

* Replace 结点 with 节点
Update the footnotes in the figures

* Update mindmap

* Reduce the size of the mindmap.png
This commit is contained in:
Yudong Jin
2023-04-09 04:32:17 +08:00
committed by GitHub
parent 3f4e32b2b0
commit 1c8b7ef559
395 changed files with 2056 additions and 2056 deletions

View File

@@ -14,20 +14,20 @@ class MaxHeap:
""" 构造方法 """
# 将列表元素原封不动添加进堆
self.max_heap = nums
# 堆化除叶点以外的其他所有
# 堆化除叶点以外的其他所有
for i in range(self.parent(self.size() - 1), -1, -1):
self.sift_down(i)
def left(self, i: int) -> int:
""" 获取左子点索引 """
""" 获取左子点索引 """
return 2 * i + 1
def right(self, i: int) -> int:
""" 获取右子点索引 """
""" 获取右子点索引 """
return 2 * i + 2
def parent(self, i: int) -> int:
""" 获取父点索引 """
""" 获取父点索引 """
return (i - 1) // 2 # 向下整除
def swap(self, i: int, j: int):
@@ -49,20 +49,20 @@ class MaxHeap:
def push(self, val: int):
""" 元素入堆 """
# 添加
# 添加
self.max_heap.append(val)
# 从底至顶堆化
self.sift_up(self.size() - 1)
def sift_up(self, i: int):
"""点 i 开始,从底至顶堆化 """
"""点 i 开始,从底至顶堆化 """
while True:
# 获取点 i 的父
# 获取点 i 的父
p = self.parent(i)
# 当“越过根点”或“点无需修复”时,结束堆化
# 当“越过根点”或“点无需修复”时,结束堆化
if p < 0 or self.max_heap[i] <= self.max_heap[p]:
break
# 交换两
# 交换两
self.swap(i, p)
# 循环向上堆化
i = p
@@ -71,9 +71,9 @@ class MaxHeap:
""" 元素出堆 """
# 判空处理
assert not self.is_empty()
# 交换根点与最右叶点(即交换首元素与尾元素)
# 交换根点与最右叶点(即交换首元素与尾元素)
self.swap(0, self.size() - 1)
# 删除
# 删除
val = self.max_heap.pop()
# 从顶至底堆化
self.sift_down(0)
@@ -81,18 +81,18 @@ class MaxHeap:
return val
def sift_down(self, i: int):
"""点 i 开始,从顶至底堆化 """
"""点 i 开始,从顶至底堆化 """
while True:
# 判断点 i, l, r 中值最大的点,记为 ma
# 判断点 i, l, r 中值最大的点,记为 ma
l, r, ma = self.left(i), self.right(i), i
if l < self.size() and self.max_heap[l] > self.max_heap[ma]:
ma = l
if r < self.size() and self.max_heap[r] > self.max_heap[ma]:
ma = r
# 若点 i 最大或索引 l, r 越界,则无需继续堆化,跳出
# 若点 i 最大或索引 l, r 越界,则无需继续堆化,跳出
if ma == i:
break
# 交换两
# 交换两
self.swap(i, ma)
# 循环向下堆化
i = ma