網站首頁 編程語言 正文
前言
如果你是一個開發人員,或多或少對樹型結構都有一定的認識,我個人對樹型數據結構是又愛又恨。二叉樹作為樹的一種,是一種重要的數據結構,也是面試官經常考的東西。這篇文章主要分享下關于二叉樹相關的知識點,并用go語言實現一個二叉樹和對二叉樹進行遍歷。
二叉樹概念
二叉樹是具有兩個節點的樹形結構,通常左邊的子樹被稱為左子樹,右邊的子樹稱為右子樹,圖示如下:
在代碼中我們可以用代碼來定義一個二叉樹結構:
type treeNode struct { Val string //節點值 left *treeNode //左節點 right *treeNode //右節點 }
二叉樹的性質
若二叉樹結點的層次從1開始,則在二叉樹第i層最多有2i-1 (i > 0)個節點。
深度為k的二叉樹至少有k個結點,最多有2i - 1個結點。
對任何一個二叉樹,如果其葉結點有n0 個,度為2的非葉結點有n2 個,則有 n0 = n2 + 1
具有n個結點的完全二叉樹的深度為?log2(?+1)?
創建二叉樹
// 創建節點 func CreateBinaryTree(data string) *treeNode { return &treeNode{data, nil, nil} } // 插入節點 func (node *treeNode) Insert(n *treeNode, data string) bool { cur := n for cur != nil { if cur.Val < data { if cur.Right != nil { cur = cur.Right } else { cur.Right = CreateBinaryTree(data) return true } } else { if cur.Left != nil { cur = cur.Left } else { cur.Left = CreateBinaryTree(data) return true } } } return false }
樹的遍歷
樹的遍歷分為三種方式,分別為前序遍歷,中序遍歷,后序遍歷。
前序遍歷(V-L-R)
前序遍歷訪問順序為先輸 root 結點,然后再輸出左子樹,然后再輸出右子樹。
我們通過遞歸的方式進行遍歷
func preOrder(root *bt) { if root != nil { fmt.Print(root.Val, " ") preOrder(root.Left) preOrder(root.Right) } }
中序遍歷(L-V-R)
中序遍歷訪問順序為先輸出 root 的左子樹,再輸 root 結點,最后輸出 root 的右子樹。
func inOrder(root *bt) { if root != nil { inOrder(root.Left) fmt.Print(root.Val, " ") inOrder(root.Right) } }
后序遍歷(L-R-V)
后序遍歷訪問順序為先輸出 root 的左子樹,最后輸出 root 的右子樹,再輸 root 結點。
func posOrder(root *bt) { if root != nil { posOrder(root.Left) posOrder(root.Right) fmt.Print(root.Val, " ") } }
原文鏈接:https://juejin.cn/post/7135758520955174920
相關推薦
- 2023-04-26 Sklearn調優之網格搜索與隨機搜索原理詳細分析_python
- 2022-06-08 兩步配置解決 IDEA新項目maven依賴問題
- 2022-10-13 Go?Excelize?API源碼閱讀SetSheetViewOptions示例解析_Golang
- 2022-05-08 Python?sns.distplot()方法的使用方法_python
- 2022-05-25 org.springframework.data.redis.RedisSystemExceptio
- 2022-06-01 c++?深入理解歸并排序的用法_C 語言
- 2023-07-06 golang中time包時間處理
- 2022-04-02 詳解Android如何自定義view實現圓形進度條_Android
- 最近更新
-
- window11 系統安裝 yarn
- 超詳細win安裝深度學習環境2025年最新版(
- Linux 中運行的top命令 怎么退出?
- MySQL 中decimal 的用法? 存儲小
- get 、set 、toString 方法的使
- @Resource和 @Autowired注解
- Java基礎操作-- 運算符,流程控制 Flo
- 1. Int 和Integer 的區別,Jav
- spring @retryable不生效的一種
- Spring Security之認證信息的處理
- Spring Security之認證過濾器
- Spring Security概述快速入門
- Spring Security之配置體系
- 【SpringBoot】SpringCache
- Spring Security之基于方法配置權
- redisson分布式鎖中waittime的設
- maven:解決release錯誤:Artif
- restTemplate使用總結
- Spring Security之安全異常處理
- MybatisPlus優雅實現加密?
- Spring ioc容器與Bean的生命周期。
- 【探索SpringCloud】服務發現-Nac
- Spring Security之基于HttpR
- Redis 底層數據結構-簡單動態字符串(SD
- arthas操作spring被代理目標對象命令
- Spring中的單例模式應用詳解
- 聊聊消息隊列,發送消息的4種方式
- bootspring第三方資源配置管理
- GIT同步修改后的遠程分支