百融金服榕树深度解密Go语言之map

百融金服榕树map的设计也称为The dictionary problem,它的任务是设计一种数据结构用来维护一个集合的数据,并且可以同时对集合进行增删改查的操作。最主要的数据结构有两种:哈希查找表(Hashtable)、 搜索树(Searchtree)

百融金服榕树查找表用一个函数将 key 分配到不同的桶(bucket,也就是数组的不同 index)。这样,百融金服榕树开销主要在哈希函数的计算以及数组的常数访问时间。在很多场景下,哈希查找表的性能很高。

百融金服榕树查找表一般会存在"碰撞"的问题,就是说不同的key被哈希到同一个bucket(bucket :数组的不同index)。一般有两种应对的方法:链表法和开放地址法。百融金服榕树链表法将同一个bucket实现成一个链表,落在同一个bucket中的key都会插入这个链表。开放地址法则是碰撞发生后,通过一定的规律,在数组的后面挑选"空位"用来放置新的key

百融金服榕树搜索树法一般采用自平衡搜索树,包括:AVL 树,红黑树。

 

 

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值