mirror of
https://github.com/krahets/hello-algo.git
synced 2026-04-13 18:00:18 +08:00
* Review the EN heading format. * Fix pythontutor headings. * Fix pythontutor headings. * bug fixes * Fix headings in **/summary.md * Revisit the CN-to-EN translation for Python code using Claude-4.5 * Revisit the CN-to-EN translation for Java code using Claude-4.5 * Revisit the CN-to-EN translation for Cpp code using Claude-4.5. * Fix the dictionary. * Fix cpp code translation for the multipart strings. * Translate Go code to English. * Update workflows to test EN code. * Add EN translation for C. * Add EN translation for CSharp. * Add EN translation for Swift. * Trigger the CI check. * Revert. * Update en/hash_map.md * Add the EN version of Dart code. * Add the EN version of Kotlin code. * Add missing code files. * Add the EN version of JavaScript code. * Add the EN version of TypeScript code. * Fix the workflows. * Add the EN version of Ruby code. * Add the EN version of Rust code. * Update the CI check for the English version code. * Update Python CI check. * Fix cmakelists for en/C code. * Fix Ruby comments
119 lines
2.2 KiB
Go
119 lines
2.2 KiB
Go
// File: print_utils.go
|
|
// Created Time: 2022-12-03
|
|
// Author: Reanon (793584285@qq.com), krahets (krahets@163.com), msk397 (machangxinq@gmail.com)
|
|
|
|
package pkg
|
|
|
|
import (
|
|
"container/list"
|
|
"fmt"
|
|
"strconv"
|
|
"strings"
|
|
)
|
|
|
|
// PrintSlice print slice
|
|
func PrintSlice[T any](nums []T) {
|
|
fmt.Printf("%v", nums)
|
|
fmt.Println()
|
|
}
|
|
|
|
// PrintList print list
|
|
func PrintList(list *list.List) {
|
|
if list.Len() == 0 {
|
|
fmt.Print("[]\n")
|
|
return
|
|
}
|
|
e := list.Front()
|
|
// Force conversion to string will affect efficiency
|
|
fmt.Print("[")
|
|
for e.Next() != nil {
|
|
fmt.Print(e.Value, " ")
|
|
e = e.Next()
|
|
}
|
|
fmt.Print(e.Value, "]\n")
|
|
}
|
|
|
|
// PrintMap print hash table
|
|
func PrintMap[K comparable, V any](m map[K]V) {
|
|
for key, value := range m {
|
|
fmt.Println(key, "->", value)
|
|
}
|
|
}
|
|
|
|
// PrintHeap print heap
|
|
func PrintHeap(h []any) {
|
|
fmt.Printf("Heap array representation:")
|
|
fmt.Printf("%v", h)
|
|
fmt.Printf("\nTree representation of heap:\n")
|
|
root := SliceToTree(h)
|
|
PrintTree(root)
|
|
}
|
|
|
|
// PrintLinkedList print 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 binary tree
|
|
func PrintTree(root *TreeNode) {
|
|
printTreeHelper(root, nil, false)
|
|
}
|
|
|
|
// printTreeHelper print binary tree
|
|
// This tree printer is borrowed from TECHIE DELIGHT
|
|
// https://www.techiedelight.com/c-program-print-binary-tree/
|
|
func printTreeHelper(root *TreeNode, prev *trunk, isRight bool) {
|
|
if root == nil {
|
|
return
|
|
}
|
|
prevStr := " "
|
|
trunk := newTrunk(prev, prevStr)
|
|
printTreeHelper(root.Right, trunk, true)
|
|
if prev == nil {
|
|
trunk.str = "———"
|
|
} else if isRight {
|
|
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)
|
|
}
|
|
|
|
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)
|
|
}
|