2022-12-03 20:25:24 +08:00
|
|
|
|
// File: print_utils.go
|
|
|
|
|
// Created Time: 2022-12-03
|
2024-02-07 22:21:18 +08:00
|
|
|
|
// Author: Reanon (793584285@qq.com), krahets (krahets@163.com), msk397 (machangxinq@gmail.com)
|
2022-12-03 20:25:24 +08:00
|
|
|
|
|
|
|
|
|
package pkg
|
|
|
|
|
|
|
|
|
|
import (
|
|
|
|
|
"container/list"
|
|
|
|
|
"fmt"
|
|
|
|
|
"strconv"
|
|
|
|
|
"strings"
|
|
|
|
|
)
|
|
|
|
|
|
2022-12-17 14:59:21 +08:00
|
|
|
|
// PrintSlice Print a slice
|
|
|
|
|
func PrintSlice[T any](nums []T) {
|
2022-12-03 20:25:24 +08:00
|
|
|
|
fmt.Printf("%v", nums)
|
|
|
|
|
fmt.Println()
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
// PrintList Print a list
|
|
|
|
|
func PrintList(list *list.List) {
|
2023-07-21 14:47:37 +08:00
|
|
|
|
if list.Len() == 0 {
|
|
|
|
|
fmt.Print("[]\n")
|
|
|
|
|
return
|
|
|
|
|
}
|
2022-12-03 20:25:24 +08:00
|
|
|
|
e := list.Front()
|
|
|
|
|
// 强转为 string, 会影响效率
|
|
|
|
|
fmt.Print("[")
|
|
|
|
|
for e.Next() != nil {
|
|
|
|
|
fmt.Print(e.Value, " ")
|
|
|
|
|
e = e.Next()
|
|
|
|
|
}
|
|
|
|
|
fmt.Print(e.Value, "]\n")
|
|
|
|
|
}
|
|
|
|
|
|
2023-01-12 20:32:06 +08:00
|
|
|
|
// PrintMap Print a hash map
|
|
|
|
|
func PrintMap[K comparable, V any](m map[K]V) {
|
|
|
|
|
for key, value := range m {
|
|
|
|
|
fmt.Println(key, "->", value)
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
// PrintHeap Print a heap
|
|
|
|
|
func PrintHeap(h []any) {
|
|
|
|
|
fmt.Printf("堆的数组表示:")
|
|
|
|
|
fmt.Printf("%v", h)
|
|
|
|
|
fmt.Printf("\n堆的树状表示:\n")
|
2023-07-26 11:04:09 +08:00
|
|
|
|
root := SliceToTree(h)
|
2023-01-12 20:32:06 +08:00
|
|
|
|
PrintTree(root)
|
|
|
|
|
}
|
|
|
|
|
|
2022-12-03 20:25:24 +08:00
|
|
|
|
// PrintLinkedList Print a linked list
|
|
|
|
|
func PrintLinkedList(node *ListNode) {
|
|
|
|
|
if node == nil {
|
|
|
|
|
return
|
|
|
|
|
}
|
|
|
|
|
var builder strings.Builder
|
|
|
|
|
for node.Next != nil {
|
|
|
|
|
builder.WriteString(strconv.Itoa(node.Val) + " -> ")
|
|
|
|
|
node = node.Next
|
|
|
|
|
}
|
|
|
|
|
builder.WriteString(strconv.Itoa(node.Val))
|
|
|
|
|
fmt.Println(builder.String())
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
// PrintTree Print a binary tree
|
|
|
|
|
func PrintTree(root *TreeNode) {
|
|
|
|
|
printTreeHelper(root, nil, false)
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
// printTreeHelper Help to print a binary tree, hide more details
|
|
|
|
|
// This tree printer is borrowed from TECHIE DELIGHT
|
|
|
|
|
// https://www.techiedelight.com/c-program-print-binary-tree/
|
2023-11-01 05:14:22 +08:00
|
|
|
|
func printTreeHelper(root *TreeNode, prev *trunk, isRight bool) {
|
2022-12-03 20:25:24 +08:00
|
|
|
|
if root == nil {
|
|
|
|
|
return
|
|
|
|
|
}
|
|
|
|
|
prevStr := " "
|
|
|
|
|
trunk := newTrunk(prev, prevStr)
|
|
|
|
|
printTreeHelper(root.Right, trunk, true)
|
|
|
|
|
if prev == nil {
|
|
|
|
|
trunk.str = "———"
|
2023-11-01 05:14:22 +08:00
|
|
|
|
} else if isRight {
|
2022-12-03 20:25:24 +08:00
|
|
|
|
trunk.str = "/———"
|
|
|
|
|
prevStr = " |"
|
|
|
|
|
} else {
|
|
|
|
|
trunk.str = "\\———"
|
|
|
|
|
prev.str = prevStr
|
|
|
|
|
}
|
|
|
|
|
showTrunk(trunk)
|
|
|
|
|
fmt.Println(root.Val)
|
|
|
|
|
if prev != nil {
|
|
|
|
|
prev.str = prevStr
|
|
|
|
|
}
|
|
|
|
|
trunk.str = " |"
|
|
|
|
|
printTreeHelper(root.Left, trunk, false)
|
|
|
|
|
}
|
|
|
|
|
|
2023-01-03 14:39:31 +08:00
|
|
|
|
// trunk Help to print tree structure
|
2022-12-03 20:25:24 +08:00
|
|
|
|
type trunk struct {
|
|
|
|
|
prev *trunk
|
|
|
|
|
str string
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
func newTrunk(prev *trunk, str string) *trunk {
|
|
|
|
|
return &trunk{
|
|
|
|
|
prev: prev,
|
|
|
|
|
str: str,
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
func showTrunk(t *trunk) {
|
|
|
|
|
if t == nil {
|
|
|
|
|
return
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
showTrunk(t.prev)
|
|
|
|
|
fmt.Print(t.str)
|
|
|
|
|
}
|