查找算法(2)--Binary chop--二分查找
1. 二分查找
  (1)说明
    元素必须是有序的,如果是无序的则要先进行排序操作。
  (2)基本思想:
    也称为是折半查找,属于有序查找算法。用给定值k先与中间结点的关键字比较,中间结点把线形表分成两个子表,若相等则查找成功;若不相等,再根据k与该中间结点关键字的比较结果确定下一步查找哪个子表,这样递归进行,直到查找到或查找结束发现表中没有这样的结点。
  (3)复杂度分析
    最坏情况下,关键词比较次数为log2(n+1),且期望时间复杂度为O(log2n);
    注:折半查找的前提条件是需要有序表顺序存储,对于静态查找表,一次排序后不再变化,折半查找能得到不错的效率。但对于需要频繁执行插入或删除操作的数据集来说,维护有序的排序会带来不小的工作量,那就不建议使用。——《大话数据结构》
2.代码
//二分查找(折半查找)
public static int binarySearch1(int a[], int value) {
int low, high, mid;
low = 0;
high = a.length - 1;
while (low <= high) {
mid = (low + high) / 2;
if (a[mid] == value)
return mid;
if (a[mid] > value)
high = mid - 1;
if (a[mid] < value)
low = mid + 1;
}
return -1;
}
//二分查找,递归版本:low 表示开始下标,high 表示最后的下标
public static int binarySearch2(int a[], int value, int low, int high) {
int mid = low + (high - low) / 2;
if (a[mid] == value)
return mid;
if (a[mid] > value)
return binarySearch2(a, value, low, mid - 1);
if (a[mid] < value)
return binarySearch2(a, value, mid + 1, high);
return -1;
}
public static void main(String[] args) {
int[] a = {49, 38, 65, 197, 76, 213, 27, 50};
int num1 = binarySearch1(a, 213);
int num2 = binarySearch2(a, 213,0,a.length-1);
System.out.println("数组的下标是:" + num1);
System.out.println("数组的下标是:" + num2);
}
查找算法(2)--Binary chop--二分查找的更多相关文章
- 查找算法(I) 顺序查找 二分查找 索引查找
		
查找 本文为查找算法的第一部分内容,包括了基本概念,顺序查找.二分查找和索引查找.关于散列表和B树查找的内容,待有空更新吧. 基本概念 查找(search)又称检索,在计算机上对数据表进行查找,就是根 ...
 - [01]Binary Search二分查找
		
Binary Search二分查找 作用:二分查找适用于有序的的数组或列表中,如果列表及数组中有n个元素,通过二分查找查询某一元素的位置需要的步骤是log2(n)(注:该log的底数是2) 1.Pyt ...
 - 数据结构和算法:Python实现二分查找(Binary_search)
		
在一个列表当中我们可以进行线性查找也可以进行二分查找,即通过不同的方法找到我们想要的数字,线性查找即按照数字从列表里一个一个从左向右查找,找到之后程序停下.而二分查找的效率往往会比线性查找更高. 一. ...
 - 查找算法(3)--Interpolation search--插值查找
		
1. 插值查找 (1)说明 在介绍插值查找之前,首先考虑一个新问题,为什么上述算法一定要是折半,而不是折四分之一或者折更多呢? 打个比方,在英文字典里面查“apple”,你下意识翻开字典是翻前面的书页 ...
 - js基本算法:冒泡排序,二分查找
		
知识扩充: 时间复杂度:算法的时间复杂度是一个函数,描述了算法的运行时间.时间复杂度越低,效率越高. 自我理解:一个算法,运行了几次时间复杂度就为多少,如运行了n次,则时间复杂度为O(n). 1.冒泡 ...
 - lintcode:Binary Search 二分查找
		
题目: 二分查找 给定一个排序的整数数组(升序)和一个要查找的整数target,用O(logn)的时间查找到target第一次出现的下标(从0开始),如果target不存在于数组中,返回-1. 样例 ...
 - Java数据结构和算法总结-数组、二分查找
		
前言:在平时开发中数组几乎是最基本也是最常用的数据类型,相比链表.二叉树等又简单很多,所以在学习数据和算法时用数组来作为一个起点再合适不过了.本篇博文的所有代码已上传 github ,对应工程的 ar ...
 - 数据结构和算法设计专题之---二分查找(Java版)
		
1.前提:二分查找的前提是需要查找的数组必须是已排序的,我们这里的实现默认为升序 2.原理:将数组分为三部分,依次是中值(所谓的中值就是数组中间位置的那个值)前,中值,中值后:将要查找的值和数组的中值 ...
 - LeetCode 704. Binary Search (二分查找)
		
题目标签:Binary Search 很标准的一个二分查找,具体看code. Java Solution: Runtime: 0 ms, faster than 100 % Memory Usage ...
 
随机推荐
- Mac原型动画设计软件Drama创建3D图层的注意事项,你知道吗?
			
Drama创建3D图层的注意事项:要跨层保留3D空间,可以使用组.它们具有保留子图层和嵌套组的3D空间的特殊功能. Drama支持通过在三维空间中定位和旋转2D图层来创建3D内容.要在3D空间中定位图 ...
 - Ubuntu 18.10 安装之后做的一点事
			
sb_release -c //查看系统代号 #更新源/etc/apt/sources.list //打开更新目录 deb https://linux.xidian.edu.cn/mirrors/ub ...
 - Pat 1003 甲级
			
#include <cstdlib> #include <cstring> #include <iostream> #include <cstdio> ...
 - jmeter从表格批量读取数据(一)
			
1.新建一个文本文档,重命名为2.csv 2.可以在文档中设置如下参数:casenum:用例编号:url:访问路径:para:访问的域名:function:请求方式:expectValue:响应值 3 ...
 - MyBatis mapper.xml中SQL处理小于号与大于号
			
这种问题在xml处理sql的程序中经常需要我们来进行特殊处理. 其实很简单,我们只需作如下替换即可避免上述的错误: < <= > >= & ' " < ...
 - nodejs中判断请求来自PC端还是移动端
			
获取req.headers["user-agent"]: var deviceAgent = req.headers["user-agent"].toLower ...
 - python基础语法7   闭包函数与装饰器
			
闭包函数: 1.闭包函数必须在函数内部定义 2.闭包函数可以引用外层函数的名字 闭包函数是 函数嵌套.函数对象.名称空间与作用域 结合体. # 直接传参 def func(x): print(x) f ...
 - SpringBoot整合Spring Data Elasticsearch
			
Spring Data Elasticsearch提供了ElasticsearchTemplate工具类,实现了POJO与elasticsearch文档之间的映射 elasticsearch本质也是存 ...
 - 第5章 Spring的事务管理
			
5.1 Spring事务管理概述 5.11 事务管理的核心接口 在Spring的所有jar包中,有一个名spring-tx-4.3.6RELEAS的jar包,是提供事务管理的依赖包.在该包的org.s ...
 - cf1158A-The Party and Sweets - (贪心+思维)
			
题意:有n个男孩,m个女孩,每个男孩给每个女孩一堆糖果.b数组表示每个男孩给出的最少糖果数,g数组表示每个女孩子收到的最大糖果数.求所有男孩给出的最小糖果总数. 解题: 先对b数组和g数组从小到大排序 ...