GoLang Tutorial - Binary Search Tree (BST) - Part 1 (Tree/Node structs with insert and print functions)
data:image/s3,"s3://crabby-images/85d34/85d34ba8b275a01907333d5276ef07a99d2d950a" alt="GCP-ICON.png"
bogotobogo.com site search:
Binary Search Tree (BST)
We'll use the following Binary Search Tree (BST):
data:image/s3,"s3://crabby-images/2b56d/2b56de52adbd87495fd1c4948bc518d61187e040" alt="BST_Input.png"
Here is the basic code : creating a Tree and a Node structs including inserting a key to the tree:
data:image/s3,"s3://crabby-images/387c4/387c4d9da690c0f51e3c912d95b1e31cb17a6978" alt="bts-code-basic-A.png"
data:image/s3,"s3://crabby-images/de13c/de13cc6d0a68767393568765fc8e4c6469436183" alt="bts-code-basic-B.png"
This code is available : bst-basic.go
Print functions - Tree Traversal
data:image/s3,"s3://crabby-images/2b56d/2b56de52adbd87495fd1c4948bc518d61187e040" alt="BST_Input.png"
data:image/s3,"s3://crabby-images/75adf/75adf709c7f9bdda81dfb11752a9a11bc62bfbec" alt="print_functions.png"
Pre Order: F B A D C E G I H
func printPreOrder(n *Node) { if n == nil { return } else { fmt.Printf("%d ", n.data) printPreOrder(n.left) printPreOrder(n.right) } }
Post Order: A C E D B H I G F
func printPostOrder(n *Node) { if n == nil { return } else { printPostOrder(n.left) printPostOrder(n.right) fmt.Printf("%c ", n.data) } }
In Order: A B C D E F G H I
func printPostOrder(n *Node) { if n == nil { return } else { printPostOrder(n.left) printPostOrder(n.right) fmt.Printf("%c ", n.data) } }
data:image/s3,"s3://crabby-images/1626d/1626d0ab7a1a6cc38f4add69a2231b40580fdbb4" alt="bts-code-print-A.png"
data:image/s3,"s3://crabby-images/a7966/a79665b16e96e2a8fc2a1f8718eb1a1b28dc08de" alt="bts-code-print-B.png"
This code is available : bts-print.go
data:image/s3,"s3://crabby-images/2b56d/2b56de52adbd87495fd1c4948bc518d61187e040" alt="BST_Input.png"
Go Tutorial
- GoLang Tutorial - HelloWorld
- Calling code in an external package & go.mod / go.sum files
- Workspaces
- Workspaces II
- Visual Studio Code
- Data Types and Variables
- byte and rune
- Packages
- Functions
- Arrays and Slices
- A function taking and returning a slice
- Conditionals
- Loops
- Maps
- Range
- Pointers
- Closures and Anonymous Functions
- Structs and receiver methods
- Value or Pointer Receivers
- Interfaces
- Web Application Part 0 (Introduction)
- Web Application Part 1 (Basic)
- Web Application Part 2 (Using net/http)
- Web Application Part 3 (Adding "edit" capability)
- Web Application Part 4 (Handling non-existent pages and saving pages)
- Web Application Part 5 (Error handling and template caching)
- Web Application Part 6 (Validating the title with a regular expression)
- Web Application Part 7 (Function Literals and Closures)
- Building Docker image and deploying Go application to a Kubernetes cluster (minikube)
- Serverless Framework (Serverless Application Model-SAM)
- Serverless Web API with AWS Lambda
- Arrays vs Slices with an array left rotation sample
- Variadic Functions
- Goroutines
- Channels ("<-")
- Channels ("<-") with Select
- Channels ("<-") with worker pools
- Defer
- GoLang Panic and Recover
- String Formatting
- JSON
- SQLite
- Modules 0: Using External Go Modules from GitHub
- Modules 1 (Creating a new module)
- Modules 2 (Adding Dependencies)
- AWS SDK for Go (S3 listing)
- Linked List
- Binary Search Tree (BST) Part 1 (Tree/Node structs with insert and print functions)
- Go Application Authentication I (BasicAuth, Bearer-Token-Based Authentication)
- Go Application Authentication II (JWT Authentication)
Ph.D. / Golden Gate Ave, San Francisco / Seoul National Univ / Carnegie Mellon / UC Berkeley / DevOps / Deep Learning / Visualization