二分查找和二叉树查找的区别

关于二分查找和二叉树的理解:

(1)二分查找即折半查找,优点是比较次数少,查找速度快,平均性能好;其缺点是要求待查表为有序表,且插入删除困难

(2)二叉查找树,它或者是一棵空树,或者若它的左子树不空,则左子树上所有结点的值均小于它的根结点的值;
若它的右子树不空,则右子树上所有结点的值均大于它的根结点的值; 它的左、右子树也分别为二叉排序树。

两者明显的区别是二分查找速度快删除和插入困难,二对于建立的二叉树索引来说,他的插入和删除是相对较快的。为什么会出现
这两者的差别其实底层更多的考虑的是数据的存储结构:

顺序存储和链式存储的概念

(1)从空间性能,顺序存储会对空间资源做到百分之百的利用,而链式存储对对空间的利用不是百分之百,因为存储了指针,不是真正的数据
(2)从时间性能上来讲读取速度的话顺序存储更优,插入和删除操作链式存储更优,链式存储只需要移动指针,不需要移动元素。

什么时候采用二分什么时候采用二叉索引

(1)如果我们的数据是不进行频繁变化且是有序,而且查询相对较多的情况下采用二分查找
(2)我们的数据是频繁变化的考虑到后面的数据扩容的情况下,我们考虑采用二叉索引的方式,但是这种会有一点空间资源的牺牲。

至于二叉查找的算法,因为从时间复杂度的算法上面考虑。两者的算法如下:

  • 二分查找时间复杂度算法:
    第一次 N/2

    第k次 N/2^k
    最坏的情况下第k次才找到,此时只剩一个数据,长度为1。
    即 N/2^k = 1
    查找次数 k=log(N)。

  • 对于二叉查找的时间复杂度算法理想状态下,他的时间复杂度和二分查找是相同的都是log(N)。
    但是, 最差情况为所有数据全部在一端时(链表无索引,需要一个一个搜索),这个时候的时间复杂度就是相当于一个一个去匹配,然后找到我们想要的那个数。这个时候的时间复杂度就变成了O(n),不在是理想状态下的O(logn)

  • 1
    点赞
  • 10
    收藏
    觉得还不错? 一键收藏
  • 2
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 2
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值