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

@@ -6,14 +6,14 @@
import utils
/* n0 P */
/* n0 P */
func insert(n0: ListNode, P: ListNode) {
let n1 = n0.next
P.next = n1
n0.next = P
}
/* n0 */
/* n0 */
func remove(n0: ListNode) {
if n0.next == nil {
return
@@ -25,7 +25,7 @@ func remove(n0: ListNode) {
P?.next = nil
}
/* 访 index */
/* 访 index */
func access(head: ListNode, index: Int) -> ListNode? {
var head: ListNode? = head
for _ in 0 ..< index {
@@ -37,7 +37,7 @@ func access(head: ListNode, index: Int) -> ListNode? {
return head
}
/* target */
/* target */
func find(head: ListNode, target: Int) -> Int {
var head: ListNode? = head
var index = 0
@@ -56,7 +56,7 @@ enum LinkedList {
/* Driver Code */
static func main() {
/* */
//
//
let n0 = ListNode(x: 1)
let n1 = ListNode(x: 3)
let n2 = ListNode(x: 2)
@@ -70,22 +70,22 @@ enum LinkedList {
print("初始化的链表为")
PrintUtil.printLinkedList(head: n0)
/* */
/* */
insert(n0: n0, P: ListNode(x: 0))
print("插入点后的链表为")
print("插入点后的链表为")
PrintUtil.printLinkedList(head: n0)
/* */
/* */
remove(n0: n0)
print("删除点后的链表为")
print("删除点后的链表为")
PrintUtil.printLinkedList(head: n0)
/* 访 */
/* 访 */
let node = access(head: n0, index: 3)
print("链表中索引 3 处的点的值 = \(node!.val)")
print("链表中索引 3 处的点的值 = \(node!.val)")
/* */
/* */
let index = find(head: n0, target: 2)
print("链表中值为 2 的点的索引 = \(index)")
print("链表中值为 2 的点的索引 = \(index)")
}
}

View File

@@ -14,23 +14,23 @@ class MaxHeap {
init(nums: [Int]) {
//
maxHeap = nums
//
//
for i in stride(from: parent(i: size() - 1), through: 0, by: -1) {
siftDown(i: i)
}
}
/* */
/* */
private func left(i: Int) -> Int {
2 * i + 1
}
/* */
/* */
private func right(i: Int) -> Int {
2 * i + 2
}
/* */
/* */
private func parent(i: Int) -> Int {
(i - 1) / 2 //
}
@@ -57,23 +57,23 @@ class MaxHeap {
/* */
func push(val: Int) {
//
//
maxHeap.append(val)
//
siftUp(i: size() - 1)
}
/* i */
/* i */
private func siftUp(i: Int) {
var i = i
while true {
// i
// i
let p = parent(i: i)
//
//
if p < 0 || maxHeap[i] <= maxHeap[p] {
break
}
//
//
swap(i: i, j: p)
//
i = p
@@ -86,9 +86,9 @@ class MaxHeap {
if isEmpty() {
fatalError("堆为空")
}
//
//
swap(i: 0, j: size() - 1)
//
//
let val = maxHeap.remove(at: size() - 1)
//
siftDown(i: 0)
@@ -96,11 +96,11 @@ class MaxHeap {
return val
}
/* i */
/* i */
private func siftDown(i: Int) {
var i = i
while true {
// i, l, r ma
// i, l, r ma
let l = left(i: i)
let r = right(i: i)
var ma = i
@@ -110,11 +110,11 @@ class MaxHeap {
if r < size(), maxHeap[r] > maxHeap[ma] {
ma = r
}
// i l, r
// i l, r
if ma == i {
break
}
//
//
swap(i: i, j: ma)
//
i = ma

View File

@@ -15,7 +15,7 @@ func hashingSearchArray(map: [Int: Int], target: Int) -> Int {
/* */
func hashingSearchLinkedList(map: [Int: ListNode], target: Int) -> ListNode? {
// key: value:
// key: value:
// key null
return map[target]
}
@@ -41,10 +41,10 @@ enum HashingSearch {
//
var map1: [Int: ListNode] = [:]
while head != nil {
map1[head!.val] = head! // key: value:
map1[head!.val] = head! // key: value:
head = head?.next
}
let node = hashingSearchLinkedList(map: map1, target: target)
print("目标点值 3 的对应点对象为 \(node!)")
print("目标点值 3 的对应点对象为 \(node!)")
}
}

View File

@@ -24,13 +24,13 @@ func linearSearchLinkedList(head: ListNode?, target: Int) -> ListNode? {
var head = head
//
while head != nil {
//
//
if head?.val == target {
return head
}
head = head?.next
}
// null
// null
return nil
}
@@ -48,6 +48,6 @@ enum LinearSearch {
/* 线 */
let head = ListNode.arrToLinkedList(arr: nums)
let node = linearSearchLinkedList(head: head, target: target)
print("目标点值 3 的对应点对象为 \(node!)")
print("目标点值 3 的对应点对象为 \(node!)")
}
}

View File

@@ -4,11 +4,11 @@
* Author: nuomi1 (nuomi1@qq.com)
*/
/* */
/* */
class ListNode {
var val: Int //
var next: ListNode? //
var prev: ListNode? //
var val: Int //
var next: ListNode? //
var prev: ListNode? //
init(val: Int) {
self.val = val
@@ -17,8 +17,8 @@ class ListNode {
/* */
class LinkedListDeque {
private var front: ListNode? // front
private var rear: ListNode? // rear
private var front: ListNode? // front
private var rear: ListNode? // rear
private var queSize: Int //
init() {
@@ -48,14 +48,14 @@ class LinkedListDeque {
// node
front?.prev = node
node.next = front
front = node //
front = node //
}
//
else {
// node
rear?.next = node
node.prev = rear
rear = node //
rear = node //
}
queSize += 1 //
}
@@ -78,25 +78,25 @@ class LinkedListDeque {
let val: Int
//
if isFront {
val = front!.val //
//
val = front!.val //
//
let fNext = front?.next
if fNext != nil {
fNext?.prev = nil
front?.next = nil
}
front = fNext //
front = fNext //
}
//
else {
val = rear!.val //
//
val = rear!.val //
//
let rPrev = rear?.prev
if rPrev != nil {
rPrev?.next = nil
rear?.prev = nil
}
rear = rPrev //
rear = rPrev //
}
queSize -= 1 //
return val

View File

@@ -8,8 +8,8 @@ import utils
/* */
class LinkedListQueue {
private var front: ListNode? //
private var rear: ListNode? //
private var front: ListNode? //
private var rear: ListNode? //
private var _size = 0
init() {}
@@ -26,14 +26,14 @@ class LinkedListQueue {
/* */
func push(num: Int) {
// num
// num
let node = ListNode(x: num)
//
//
if front == nil {
front = node
rear = node
}
//
//
else {
rear?.next = node
rear = node
@@ -45,7 +45,7 @@ class LinkedListQueue {
@discardableResult
func pop() -> Int {
let num = peek()
//
//
front = front?.next
_size -= 1
return num

View File

@@ -8,7 +8,7 @@ import utils
/* */
class LinkedListStack {
private var _peek: ListNode? //
private var _peek: ListNode? //
private var _size = 0 //
init() {}

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)")
}
}

View File

@@ -5,8 +5,8 @@
*/
public class ListNode {
public var val: Int //
public var next: ListNode? //
public var val: Int //
public var next: ListNode? //
public init(x: Int) {
val = x

View File

@@ -5,10 +5,10 @@
*/
public class TreeNode {
public var val: Int //
public var height: Int //
public var left: TreeNode? //
public var right: TreeNode? //
public var val: Int //
public var height: Int //
public var left: TreeNode? //
public var right: TreeNode? //
public init(x: Int) {
val = x