Go语言树结构:二叉树与AVL树
Go语言树结构二叉树与AVL树1. 二叉树实现type TreeNode struct { Val int Left *TreeNode Right *TreeNode } type BinaryTree struct { Root *TreeNode } func (t *BinaryTree) Insert(val int) { t.Root insert(t.Root, val) } func insert(node *TreeNode, val int) *TreeNode { if node nil { return TreeNode{Val: val} } if val node.Val { node.Left insert(node.Left, val) } else { node.Right insert(node.Right, val) } return node } func (t *BinaryTree) Search(val int) bool { return search(t.Root, val) } func search(node *TreeNode, val int) bool { if node nil { return false } if val node.Val { return true } if val node.Val { return search(node.Left, val) } return search(node.Right, val) }2. 总结树结构是计算机科学中最重要的数据结构之一二叉树广泛应用于搜索、排序等场景。
本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/2614139.html
如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!