GO中二叉树的实现必知必会

前言

如果你是一个开发人员,或多或少对树型结构都有一定的认识,我个人对树型数据结构是又爱又恨。二叉树作为树的一种,是一种重要的数据结构,也是面试官经常考的东西。这篇文章主要分享下关于二叉树相关的知识点,并用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, " ")
    }
}
#java#
全部评论

相关推荐

10-24 11:10
山西大学 Java
若梦难了:哥们,面试挂是很正常的。我大中厂终面挂,加起来快10次了,继续努力吧。
点赞 评论 收藏
分享
牛客771574427号:恭喜你,华杰
点赞 评论 收藏
分享
点赞 收藏 评论
分享
牛客网
牛客企业服务