川山甲

追求内心的非常平静!瞬间清空所有的杂念,达到物我两忘!

  博客园  :: 首页  ::  :: 联系 :: 订阅 订阅  :: 管理
  105 随笔 :: 0 文章 :: 1591 评论 :: 82万 阅读
 
 
  承接上文浅谈大型网站的算法和架构(一) ,我们继续聊我们的话题。
  上文中很多人提到不扣题,这只是一部分资料,所以会感觉到不扣题,主要是题目太大了,而且内容太多了,我只能一部分一部分的写出来,望大家见谅。
  

  我们老大也只讲到上,还有中和下呢!
  上偏重于基础部分——就是算法部分。里面包括现今架构中的产品使用的算法,让我们了解产品本质的一些东西。需要到伸展树这一篇开始才能真正讲到相关架构产品。

  中和下他还没开始呢!估计也够我研究一段时间了。大家就权当了解下算法吧!

 
二叉树
 
 上文中提到的两个结构(数组和链表)各有弊端。
  1》数组在更新的时候比较消耗资源,需要挨个挪动后面的元素。
  2》而链表在查询的时候需要从头挨个对比之后选择出要查询的内容。

 
  综上我们需要一个查询更快,更新更快的结构,于是我们有了二叉树。
 特点:
  每个结点最多有两棵子树。

找80
 
 
我们来看看代码实践:

                                    让我们运行起来看看

插入82
 

我们来看看代码实践(注意:在原有的代码上加了一个方法insert_bit_tree):

                                    让我们运行起来看看

二叉树的烦恼

 

我们不难发现如果在一个很极端的情况下,查找某个数据,那么会出现上图的情况。你猜想一下,如果是几千万条数据,会出现什么情况呢?


由于上述原因,我们想到了平衡二叉树,又叫AVL树。

平衡二叉树:AVL Tree(1962)
 

让我们看看代码实践。

                                    主要理解一下这段代码 

                                    对该函数进行图解。

 


由于篇幅太长,下篇将继续介绍。

 
 
推荐
 

 

posted on   川山甲  阅读(5178)  评论(14编辑  收藏  举报
编辑推荐:
· Linux系列:如何用 C#调用 C方法造成内存泄露
· AI与.NET技术实操系列(二):开始使用ML.NET
· 记一次.NET内存居高不下排查解决与启示
· 探究高空视频全景AR技术的实现原理
· 理解Rust引用及其生命周期标识(上)
阅读排行:
· 阿里最新开源QwQ-32B,效果媲美deepseek-r1满血版,部署成本又又又降低了!
· 单线程的Redis速度为什么快?
· 展开说说关于C#中ORM框架的用法!
· SQL Server 2025 AI相关能力初探
· Pantheons:用 TypeScript 打造主流大模型对话的一站式集成库
点击右上角即可分享
微信分享提示