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

@@ -8,25 +8,25 @@ import utils
/* AVL */
class AVLTree {
fileprivate var root: TreeNode? //
fileprivate var root: TreeNode? //
/* */
/* */
func height(node: TreeNode?) -> Int {
// -1 0
// -1 0
node == nil ? -1 : node!.height
}
/* */
/* */
private func updateHeight(node: TreeNode?) {
// + 1
// + 1
node?.height = max(height(node: node?.left), height(node: node?.right)) + 1
}
/* */
func balanceFactor(node: TreeNode?) -> Int {
// 0
// 0
guard let node = node else { return 0 }
// = -
// = -
return height(node: node.left) - height(node: node.right)
}
@@ -37,10 +37,10 @@ class AVLTree {
// child node
child?.right = node
node?.left = grandChild
//
//
updateHeight(node: node)
updateHeight(node: child)
//
//
return child
}
@@ -51,16 +51,16 @@ class AVLTree {
// child node
child?.left = node
node?.right = grandChild
//
//
updateHeight(node: node)
updateHeight(node: child)
//
//
return child
}
/* 使 */
private func rotate(node: TreeNode?) -> TreeNode? {
// node
// node
let balanceFactor = balanceFactor(node: node)
//
if balanceFactor > 1 {
@@ -88,48 +88,48 @@ class AVLTree {
return node
}
/* */
/* */
@discardableResult
func insert(val: Int) -> TreeNode? {
root = insertHelper(node: root, val: val)
return root
}
/* */
/* */
private func insertHelper(node: TreeNode?, val: Int) -> TreeNode? {
var node = node
if node == nil {
return TreeNode(x: val)
}
/* 1. */
/* 1. */
if val < node!.val {
node?.left = insertHelper(node: node?.left, val: val)
} else if val > node!.val {
node?.right = insertHelper(node: node?.right, val: val)
} else {
return node //
return node //
}
updateHeight(node: node) //
updateHeight(node: node) //
/* 2. 使 */
node = rotate(node: node)
//
//
return node
}
/* */
/* */
@discardableResult
func remove(val: Int) -> TreeNode? {
root = removeHelper(node: root, val: val)
return root
}
/* */
/* */
private func removeHelper(node: TreeNode?, val: Int) -> TreeNode? {
var node = node
if node == nil {
return nil
}
/* 1. */
/* 1. */
if val < node!.val {
node?.left = removeHelper(node: node?.left, val: val)
} else if val > node!.val {
@@ -137,59 +137,59 @@ class AVLTree {
} else {
if node?.left == nil || node?.right == nil {
let child = node?.left != nil ? node?.left : node?.right
// = 0 node
// = 0 node
if child == nil {
return nil
}
// = 1 node
// = 1 node
else {
node = child
}
} else {
// = 2
// = 2
let temp = getInOrderNext(node: node?.right)
node?.right = removeHelper(node: node?.right, val: temp!.val)
node?.val = temp!.val
}
}
updateHeight(node: node) //
updateHeight(node: node) //
/* 2. 使 */
node = rotate(node: node)
//
//
return node
}
/* root */
/* root */
private func getInOrderNext(node: TreeNode?) -> TreeNode? {
var node = node
if node == nil {
return node
}
// 访
// 访
while node?.left != nil {
node = node?.left
}
return node
}
/* */
/* */
func search(val: Int) -> TreeNode? {
var cur = root
while cur != nil {
// cur
// cur
if cur!.val < val {
cur = cur?.right
}
// cur
// cur
else if cur!.val > val {
cur = cur?.left
}
//
//
else {
break
}
}
//
//
return cur
}
}
@@ -198,13 +198,13 @@ class AVLTree {
enum _AVLTree {
static func testInsert(tree: AVLTree, val: Int) {
tree.insert(val: val)
print("\n插入\(val)AVL 树为")
print("\n插入\(val)AVL 树为")
PrintUtil.printTree(root: tree.root)
}
static func testRemove(tree: AVLTree, val: Int) {
tree.remove(val: val)
print("\n删除\(val)AVL 树为")
print("\n删除\(val)AVL 树为")
PrintUtil.printTree(root: tree.root)
}
@@ -213,8 +213,8 @@ enum _AVLTree {
/* AVL */
let avlTree = AVLTree()
/* */
// AVL
/* */
// AVL
testInsert(tree: avlTree, val: 1)
testInsert(tree: avlTree, val: 2)
testInsert(tree: avlTree, val: 3)
@@ -226,17 +226,17 @@ enum _AVLTree {
testInsert(tree: avlTree, val: 10)
testInsert(tree: avlTree, val: 6)
/* */
/* */
testInsert(tree: avlTree, val: 7)
/* */
// AVL
testRemove(tree: avlTree, val: 8) // 0
testRemove(tree: avlTree, val: 5) // 1
testRemove(tree: avlTree, val: 4) // 2
/* */
// AVL
testRemove(tree: avlTree, val: 8) // 0
testRemove(tree: avlTree, val: 5) // 1
testRemove(tree: avlTree, val: 4) // 2
/* */
/* */
let node = avlTree.search(val: 7)
print("\n查找到的点对象为 \(node!)点值 = \(node!.val)")
print("\n查找到的点对象为 \(node!)点值 = \(node!.val)")
}
}

View File

@@ -15,7 +15,7 @@ class BinarySearchTree {
root = buildTree(nums: nums, i: 0, j: nums.count - 1) //
}
/* */
/* */
func getRoot() -> TreeNode? {
root
}
@@ -25,7 +25,7 @@ class BinarySearchTree {
if i > j {
return nil
}
//
//
let mid = (i + j) / 2
let root = TreeNode(x: nums[mid])
//
@@ -34,29 +34,29 @@ class BinarySearchTree {
return root
}
/* */
/* */
func search(num: Int) -> TreeNode? {
var cur = root
//
//
while cur != nil {
// cur
// cur
if cur!.val < num {
cur = cur?.right
}
// cur
// cur
else if cur!.val > num {
cur = cur?.left
}
//
//
else {
break
}
}
//
//
return cur
}
/* */
/* */
func insert(num: Int) -> TreeNode? {
//
if root == nil {
@@ -64,9 +64,9 @@ class BinarySearchTree {
}
var cur = root
var pre: TreeNode?
//
//
while cur != nil {
//
//
if cur!.val == num {
return nil
}
@@ -80,7 +80,7 @@ class BinarySearchTree {
cur = cur?.left
}
}
// val
// val
let node = TreeNode(x: num)
if pre!.val < num {
pre?.right = node
@@ -90,7 +90,7 @@ class BinarySearchTree {
return node
}
/* */
/* */
@discardableResult
func remove(num: Int) -> TreeNode? {
//
@@ -99,43 +99,43 @@ class BinarySearchTree {
}
var cur = root
var pre: TreeNode?
//
//
while cur != nil {
//
//
if cur!.val == num {
break
}
pre = cur
// cur
// cur
if cur!.val < num {
cur = cur?.right
}
// cur
// cur
else {
cur = cur?.left
}
}
//
//
if cur == nil {
return nil
}
// = 0 or 1
// = 0 or 1
if cur?.left == nil || cur?.right == nil {
// = 0 / 1 child = null /
// = 0 / 1 child = null /
let child = cur?.left != nil ? cur?.left : cur?.right
// cur
// cur
if pre?.left === cur {
pre?.left = child
} else {
pre?.right = child
}
}
// = 2
// = 2
else {
// cur
// cur
let nex = getInOrderNext(root: cur?.right)
let tmp = nex!.val
// nex
// nex
remove(num: nex!.val)
// nex cur
cur?.val = tmp
@@ -143,13 +143,13 @@ class BinarySearchTree {
return cur
}
/* root */
/* root */
func getInOrderNext(root: TreeNode?) -> TreeNode? {
var root = root
if root == nil {
return root
}
// 访
// 访
while root?.left != nil {
root = root?.left
}
@@ -167,24 +167,24 @@ enum _BinarySearchTree {
print("\n初始化的二叉树为\n")
PrintUtil.printTree(root: bst.getRoot())
/* */
/* */
var node = bst.search(num: 7)
print("\n查找到的点对象为 \(node!)点值 = \(node!.val)")
print("\n查找到的点对象为 \(node!)点值 = \(node!.val)")
/* */
/* */
node = bst.insert(num: 16)
print("\n插入点 16 后,二叉树为\n")
print("\n插入点 16 后,二叉树为\n")
PrintUtil.printTree(root: bst.getRoot())
/* */
/* */
bst.remove(num: 1)
print("\n删除点 1 后,二叉树为\n")
print("\n删除点 1 后,二叉树为\n")
PrintUtil.printTree(root: bst.getRoot())
bst.remove(num: 2)
print("\n删除点 2 后,二叉树为\n")
print("\n删除点 2 后,二叉树为\n")
PrintUtil.printTree(root: bst.getRoot())
bst.remove(num: 4)
print("\n删除点 4 后,二叉树为\n")
print("\n删除点 4 后,二叉树为\n")
PrintUtil.printTree(root: bst.getRoot())
}
}

View File

@@ -11,7 +11,7 @@ enum BinaryTree {
/* Driver Code */
static func main() {
/* */
//
//
let n1 = TreeNode(x: 1)
let n2 = TreeNode(x: 2)
let n3 = TreeNode(x: 3)
@@ -25,16 +25,16 @@ enum BinaryTree {
print("\n初始化二叉树\n")
PrintUtil.printTree(root: n1)
/* */
/* */
let P = TreeNode(x: 0)
// n1 -> n2 P
// n1 -> n2 P
n1.left = P
P.left = n2
print("\n插入点 P 后\n")
print("\n插入点 P 后\n")
PrintUtil.printTree(root: n1)
// P
// P
n1.left = n2
print("\n删除点 P 后\n")
print("\n删除点 P 后\n")
PrintUtil.printTree(root: n1)
}
}

View File

@@ -8,18 +8,18 @@ import utils
/* */
func levelOrder(root: TreeNode) -> [Int] {
//
//
var queue: [TreeNode] = [root]
//
var list: [Int] = []
while !queue.isEmpty {
let node = queue.removeFirst() //
list.append(node.val) //
list.append(node.val) //
if let left = node.left {
queue.append(left) //
queue.append(left) //
}
if let right = node.right {
queue.append(right) //
queue.append(right) //
}
}
return list
@@ -37,6 +37,6 @@ enum BinaryTreeBFS {
/* */
let list = levelOrder(root: node)
print("\n层序遍历的点打印序列 = \(list)")
print("\n层序遍历的点打印序列 = \(list)")
}
}

View File

@@ -14,7 +14,7 @@ func preOrder(root: TreeNode?) {
guard let root = root else {
return
}
// 访 -> ->
// 访 -> ->
list.append(root.val)
preOrder(root: root.left)
preOrder(root: root.right)
@@ -25,7 +25,7 @@ func inOrder(root: TreeNode?) {
guard let root = root else {
return
}
// 访 -> ->
// 访 -> ->
inOrder(root: root.left)
list.append(root.val)
inOrder(root: root.right)
@@ -36,7 +36,7 @@ func postOrder(root: TreeNode?) {
guard let root = root else {
return
}
// 访 -> ->
// 访 -> ->
postOrder(root: root.left)
postOrder(root: root.right)
list.append(root.val)
@@ -55,16 +55,16 @@ enum BinaryTreeDFS {
/* */
list.removeAll()
preOrder(root: root)
print("\n前序遍历的点打印序列 = \(list)")
print("\n前序遍历的点打印序列 = \(list)")
/* */
list.removeAll()
inOrder(root: root)
print("\n中序遍历的点打印序列 = \(list)")
print("\n中序遍历的点打印序列 = \(list)")
/* */
list.removeAll()
postOrder(root: root)
print("\n后序遍历的点打印序列 = \(list)")
print("\n后序遍历的点打印序列 = \(list)")
}
}