本文小编为大家详细介绍“web二叉树实例代码分析”,内容详细,步骤清晰,细节处理妥当,希望这篇“web二叉树实例代码分析”文章能帮助大家解决疑惑,下面跟着小编的思路慢慢深入,一起来学习新知识吧。
二叉树
上文中提到的两个结构(数组和链表)各有弊端。
1》数组在更新的时候比较消耗资源,需要挨个挪动后面的元素。
2》而链表在查询的时候需要从头挨个对比之后选择出要查询的内容。
综上我们需要一个查询更快,更新更快的结构,于是我们有了二叉树。
特点:
每个结点最多有两棵子树。
找80
我们来看看代码实践:
让我们运行起来看看
插入82
我们来看看代码实践(注意:在原有的代码上加了一个方法insert_bit_tree):
让我们运行起来看看
二叉树的烦恼
我们不难发现如果在一个很极端的情况下,查找某个数据,那么会出现上图的情况。你猜想一下,如果是几千万条数据,会出现什么情况呢?
由于上述原因,我们想到了平衡二叉树,又叫AVL树。
平衡二叉树:AVL Tree(1962)
让我们看看代码实践。
主要理解一下这段代码
对该函数进行图解。
读到这里,这篇“web二叉树实例代码分析”文章已经介绍完毕,想要掌握这篇文章的知识点还需要大家自己动手实践使用过才能领会,如果想了解更多相关内容的文章,欢迎关注亿速云行业资讯频道。
免责声明:本站发布的内容(图片、视频和文字)以原创、转载和分享为主,文章观点不代表本网站立场,如果涉及侵权请联系站长邮箱:is@yisu.com进行举报,并提供相关证据,一经查实,将立刻删除涉嫌侵权内容。