二分查找和二叉查找树

2019独角兽企业重金招聘Python工程师标准>>> hot3.png

1  二分查找

算法思想:

二分查找要求元素排列有序。首先,假设表中元素是按升序排列,将数组中间位置的元素与查找关键字比较,如果两者相等,则查找成功;否则利用中间位置记录将数组分成前、后两个子数组,如果中间位置记录的元素大于查找关键字,则进一步查找前一子数组,否则进一步查找后一子数组。重复以上过程,直到找到满足条件的记录,使查找成功,或直到子表不存在为止,此时查找不成功。

二分查找的时间复杂度为O(logN)

算法实现:

递归算法:

//递归算法
public int rank(Key key, int lo, int hi) {if(hi<lo)	return lo;int mid = lo + (hi-lo)/2;int cmp = key.compareTo(keys[mid]);if(cmp<0)	return rank(key,lo,hi-1);if(cmp>0)	return rank(key,mid+1,hi);else return mid;
}

非递归算法:

//非递归算法
public int rank(Key key) {int lo = 0, hi = N-1;while(lo<=hi) {int mid = lo + (hi-lo)/2;int cmp = key.compareTo(keys[mid]);if(cmp<0)	hi = mid-1;if(cmp>0)	lo = mid+1;else return mid;}return lo;
}

2  二叉查找树

定义:

二叉排序树或者是一棵空树,或者是具有下列性质的二叉树:

  • 若左子树不空,则左子树上所有结点的值均小于或等于它的根结点的值;
  • 若右子树不空,则右子树上所有结点的值均大于或等于它的根结点的值;
  • 左、右子树也分别为二叉排序树;

步骤:

若根结点的关键字值等于查找的关键字,成功。否则,若小于根结点的关键字值,递归查左子树。若大于根结点的关键字值,递归查右子树。若子树为空,查找不成功。

二叉查找树的时间复杂度为O(logN)

算法实现:

结点类:

private class Node{private Key key;private Value val;private Node left,right;private int N;public Node(Key key,Value val, int N) {	this.key = key; this.val = val; this.N = N; }
}

其中N为以该节点为根的子树的节点总数,计算方法如下:

size(x) = size(x.left) + size(x.right) + 1

 查找方法:

递归查找,如果小于当前结点,递归去左子树查找;如果大于当前结点,递归去右子树查找。

public Value get(Key key) {return get(root,key);
}
public Value get(Node x,Key key) {if(x==null)return null;int cmp = key.compareTo(x.key);if(cmp<0)	return get(x.left,key);if(cmp>0)	return get(x.right,key);else return x.val;
}

插入方法:

先查找,如果树中已经存在相应的键,只需更新值;如果查询无果,指针也已经指向了应该插入的位置,用要插入的键值对新创结点并插入到相关位置。

public void put(Key key,Value val) {root = put(root,key,val);
}
private Node put(Node x,Key key,Value val) {if(x == null) return new Node(key,val,1);int cmp = key.compareTo(x.key);if(cmp<0)	x.left = put(x.left,key,val);//插入左子树if(cmp>0)	x.right = put(x.right,key,val);//插入右子树else x.val = val;//更新值x.N = size(x.left) + size(x.right)+1;return x;
}

删除方法:

  1. 即将被删除的节点记为t
  2. x指向它的后继节点min(t.right)
  3. 将x的右链接链接到x的父节点的左链接上(即替换掉原x的位置)
  4. 用x节点替换t节点(将t.left和t.right设为x.left和x.right)
public void delete(Key key) {root = delete(root,key);
}
private Node delete(Node x,Key key) {if(x == null)	return null;int cmp = key.compareTo(x.key);if(cmp<0)	x.left = delete(x.left,key);if(cmp>0)	x.right = delete(x.right,key);else {if(x.right == null)		return x.left;if(x.left == null)		return x.right;Node t = x;x = min(t.right);x.right = deleteMin(t.right);x.left = t.left;}x.N = size(x.left)+size(x.right)+1;return x;
}

 

转载于:https://my.oschina.net/HuoQibin/blog/1590855

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/539827.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

springboot判断有没有库_Springboot 使用JPA @Query 注解 查询语句条件 有可能为空,Oracle数据库...

网上查了很多资料都是下面的方法,但是不适用于OracleQuery(value "select * from xxx where if(?1 !,x1?1,11) and if(?2 !,x2?2,11)" "and if(?3 !,x3?3,11) ",nativeQuery true)List find(String X1,String X2,String X3);——————————…

台式计算机技术方案,2017年4月自考02316计算机应用技术真题及答案

本文提供的是2017年4月自考02316计算机应用技术真题及答案&#xff0c;真题不仅能帮助考生复习巩固学到的知识&#xff0c;还能让考生了解以往考试难易程度&#xff0c;真正掌握一套真题那么考试也不用担心了。要考试的你一定要多多练习啊。2017 年 4 月高等教育自学考试全国统…

Linux磁盘编号

一、IDE接口磁盘 Linux的编码规则是 /dev/hd* -------------------------------hda 第一块盘 -------------------------------------------hda1 第一分区&#xff0c;hda2 第二分区&#xff0c;hda3 第三分区..... -------------------------------hdb 第二块盘 …

Linux挂载点和文件系统类型介绍

一、挂载点 Mount Point 这是Linux下访问磁盘分区的入口&#xff0c;即如果要往分区里写入数据&#xff0c;就必须通过/boot入口来写入&#xff0c;这一点和windows是不同的&#xff0c;因为在安装Linux时&#xff0c;Mount Point项填写 /boot二、文件系统类型 1、ext2/3/4&…

pythonint函数的参数_向嵌入的Python函数传递两个参数(int和array)

我需要从我的模块中调用Python函数并为其设置两个参数&#xff1a;int和array。在现在我在调用这个函数的时候遇到了segfault&#xff0c;我不知道我做错了什么。有人能指出我的错误在哪里吗&#xff1f;在函数在我的Python模块中应用程序副本. 如果我从Python代码调用它&#…

理解lua中 . : self

文章目录[点击展开](?)[] 前言点号定义和调用冒号定义和冒号调用运行结果相互调用相互调用运行结果总结前言 在LUA中&#xff0c;经常可以看到&#xff1a;. self&#xff0c;今天在CSDN上看到一篇博客写的很清楚&#xff0c;转载过来 原文出处&#xff1a;http://blog.csdn.n…

适合初中文凭学的计算机技术,初中毕业学啥技术好 最吃香的手艺

很多初中毕业的初中生因为成绩不是很理想&#xff0c;不能上一所理想的高中&#xff0c;所以选择学一门技术&#xff0c;那么初中毕业学啥技术好呢&#xff0c;哪些手艺未来比较吃香呢&#xff0c;下面小编为大家分析一下初中毕业应该学什么手艺。初中毕业学哪些技术发展好汽修…

SecureCRT配置

一、下载 路径&#xff1a;http://www.pc6.com/softview/softview_24396.html 里面有破解教程 二、配置 1、选择仿真环境养眼的绿色字体黑色背景配置&#xff0c;选择 traditional option->Global options –>default session -> edit default settings -> 修改…

左室短轴切面_一文读懂心脏超声基本切面

一. 本文出现的英文简称二.超声心动图基本切面采用与心脏相互垂直的三个基本平面&#xff0c;主要观测心脏各房室腔内径、容积和室壁厚度及其相关解剖结构运动状态、功能等。检查中探头最常放置的位置包括心底部、心尖部、剑突下&#xff0c;锁骨/胸骨上窝等。心脏超声检查中探…

怎么用计算机弹c哩c哩,计算器音乐c哩c哩乐谱 | 手游网游页游攻略大全

发布时间&#xff1a;2016-06-29铲子骑士乐谱有什么用 铲子骑士乐谱卖不了怎么办.不少铲子骑士玩家收集了一些乐谱,那么这些乐谱功能是什么呢?下面99单机网小编给大家介绍铲子骑士乐谱有什么用 铲子骑士乐谱卖不了怎么办. 乐谱可以卖钱,还可以更换游戏中的音乐 ...标签&#x…

Windows 7 资源管理器搜索Channel 9 视频

在Windows 7 中Federated Search 可以通过OpenSearch 协议访问到远程数据资源&#xff0c;也就意味着用户可以使用资源管理器&#xff08;Windows Explorer&#xff09;搜索并浏览远程数据。本篇我们将制作一个搜索连接器&#xff08;Search Connector&#xff09;查找Channel …

python django flask介绍_django和flask哪个值得研究学习

对于初学者来说&#xff0c;找到一个好的框架来学习或者项目开发都是非常有必要的&#xff0c;而当你有一定开发经验后&#xff0c;你应该选择适合当前业务需要的框架。我这里并不想探讨哪个框架好哪个不好&#xff0c;这个永恒的话题就跟探讨“世界上哪种编程语言最屌”是一样…

sts html视图编辑器,免费的HTML可视化编辑器HBuilder前端开发编辑器 | 老疯子

互联网上几款比较热门的编辑器Dreamweaver、Notepad、Sublime Text、Vim、Emacs等&#xff0c;这些或许你用过其中之一或许听说过它们。这些都是国外人员开发的有些甚至被公认为是最受专业程序员喜爱的代码编辑器(Vim和Emacs)。都是国外的&#xff0c;那国内的呢&#xff1f;当…

css层叠样式初学

一、css简介 1、层叠样式表&#xff1a;叠加效果&#xff0c;不同css对同一html修饰&#xff0c;冲突部分&#xff0c;优先级高作用&#xff0c;不冲突部分&#xff0c;共同作用 2、css作用 (1)修饰html     (2)替代了标签自身的颜色&#xff0c;字号等属性&#xff0c;提高…

sum(x) over( partition by y ORDER BY z ) 分析

参考的博文出处&#xff1a;http://www.cnblogs.com/luhe/p/4155612.html&#xff0c;对博文进行了修改新增&#xff0c;修改了错误的地方 之前用过row_number()&#xff0c;rank()等排序与over( partition by ... ORDER BY ...)&#xff0c;这两个比较好理解: 先分组&#xff…

sqlserver 日期与字符串之间的转换

字符转换为日期时,Style的使用 --1. Style101时,表示日期字符串为:mm/dd/yyyy格式SELECT CONVERT(datetime,11/1/2003,101)--结果:2003-11-01 00:00:00.000 --2. Style101时,表示日期字符串为:dd/mm/yyyy格式SELECT CONVERT(datetime,11/1/2003,103)--结果:2003-01-11 00:00:00…

idea数据库反向生成实体类_IntelliJ IDEA 的数据库管理工具实在太方便了

1. 前言对于一个有软件洁癖的人&#xff0c;能用现有的软件解决问题的绝不安装新的软件。Java后端开发主要跟数据库打交道&#xff0c;所以数据库图形化界面&#xff08;GUI&#xff09;是少不了的。通常图形化操作关系型数据库&#xff08;RMDBS&#xff09;大多数人会选择Nav…

DBMS_OUTPUT.PUT_LINE没有输出

解决方法&#xff1a; 打开打印输出 set serveroutput on;问&#xff1a; 明明设了&#xff0c;但是还是没有打印啊&#xff01; 答&#xff1a; 只有在调用 存储过程的时候&#xff0c;才会打印出来。在创建编译的时候&#xff0c;是不会打印出来的。 &#xff08;博主今天…

Fresco 二三事:图片处理之旋转、缩放、裁剪切割图片

关于Fresco加载图片的处理&#xff0c;例如旋转、裁剪切割图片&#xff0c;在官方文档也都有提到&#xff0c;只是感觉写的不太详细&#xff0c;正好最近项目里有类似需求&#xff0c;所以分享一些使用小tip&#xff0c;后面的朋友就不用再走弯路浪费时间了。&#xff08;测试图…

老年人计算机应用基础,国开电大老年心理健康作业一参考答案

题目1.脑功能衰退明显的症状是( )。A. 记忆力衰退B. 皮肤老化C. 孤独感强D. 感知觉能力的退化【答案】&#xff1a;记忆力衰退题目2.下列哪项不属于老年人的特点&#xff1a;( )。A. 肺功能下降B. 体重下降C. 视野狭窄D. 嗜睡【答案】&#xff1a;嗜睡题目3.下列不是诊断老年…