首页 > 编程语言 >算法回顾之三:二分查找

算法回顾之三:二分查找

时间:2023-09-14 14:32:09浏览次数:42  
标签:二分 return target int 之三 查找 input 子表


算法回顾系列第三篇:二分查找算法

------------------------------------------------

二分查找算法

 

基本原理:

首先,假设表中元素是按升序排列.

将表中间位置记录的关键字与查找关键字比较,如果两者相等,则查找成功.

否则利用中间位置记录将表分成前、后两个子表,如果中间位置记录的关键字大于查找关键字,则进一步查找前一子表,否则进一步查找后一子表.

重复以上过程(使用递归),直到找到满足条件的记录,使查找成功,或直到子表不存在为止.

 

程序实现:

/**
    * 二分查找 
    * @param input 已排序的待查数组.
    * @param target 需要插入的数.
    * @param from 当前数组查找范围的起点(0).
    * @param to 当前数组查找范围的终点(length-1).
    * @return 返回目标在数组中,按顺序应在的位置.       
    */
    private static int binarySearch(int[] input, int target, int from, int to){
    	int range = to-from;//如果范围大于0,即存在两个以上的元素(子表),则继续拆分
    	if(range > 0){
    		//选定中间位
    		int mid = (to+from)/2;
    		//如果临界位不满足,则继续二分查找 
    		if (input[mid] > target){//中间位置的元素值大于目标元素(改为小于代表逆序)
    			return binarySearch(input,target,from,mid-1);//在0至中间位置查找
    		}else{//中间位置的元素值小于目标元素
    			return binarySearch(input,target,mid+1,to);//在中间位置到末尾位置查找
    		}
    	}else{
          	if (input[from] > target){//改为小于代表逆序
          		return from;
          	}else{
          		return from + 1;
          	}
    	}
    }

优点:比较次数少,查找速度快,平均性能好.

缺点:要求待查表为有序表,且插入删除困难.

二分查找方法适用于不经常变动而查找频繁的有序列表.

 

标签:二分,return,target,int,之三,查找,input,子表
From: https://blog.51cto.com/u_6978506/7470162

相关文章

  • 用c++ 实现 二分查找 前提是先把数组排列好
    #include<iostream>usingnamespacestd;//可以递归调用的二分查找intsearch(constint(&a)[10],intstart,intend,inttarget){ //基准情况:目标值超出范围,或者start>end,说明没有找到 if(target<a[start]||target>a[end]||start>end) return-1; //取二分......
  • Java实现常见查找算法
    Java实现常见查找算法查找是在大量的信息中寻找一个特定的信息元素,在计算机应用中,查找是常用的基本运算,例如编译程序中符号表的查找。线性查找线性查找(LinearSearch)是一种简单的查找算法,用于在数据集中逐一比较每个元素,直到找到目标元素或搜索完整个数据集。它适用于任何类型......
  • Glang 数组的排序和查找:快速丶希尔丶堆丶选择丶冒泡...
    一.数组的排序与查找1//数组的排序和查找2functestArrSort(){3//内部排序:将需要处理的所有数据都加载到内部存储器中进行排序(交换式排序法、选择式排序法、插入式排序)45//交换式排序法-冒泡排序:递归将最大或最小值冒泡到数组尾6Bu......
  • Linux之查找过滤(tail、grep、find)
    参考:https://www.cnblogs.com/caoweixiong/p/15218826.htmltail基本格式tail[-f][-cNumber|-nNumber|-mNumber|-bNumber|-kNumber][File]参数解释-f该参数用于监视File文件增长。-cNumber从Number字节位置读取指定文件-nNumber从Number行......
  • emacs查找光标处单词
     按下 C-sC-w 搜索光标处的单词(此时应该是“mail”).让我们再试试按下 C-sC-wC-w 会发现可以搜索光标处的多个单词.按下 C-sC-M-y 则表示搜索光标处的字符.类似的,按下 C-M-yC-M-y 会将接下来的两个字符也纳入搜索字符串中.按下 C-M-w 会删除搜索字符串中最......
  • 001.查找命令和实用快捷键
    1、ctrl+R查找使用过的命令,按回车运行2、history    !+对应的序号运行命令 3、ctrl+l清屏目 4、ctrl+D文件结束符号 ......
  • 基础总结篇之三:Activity的task相关
    古人學問無遺力,少壯工夫老始成。紙上得來終覺淺,絕知此事要躬行。南宋.陸遊《冬夜讀書示子聿(yù)》软件行业也是一样,多少前辈不遗余力的奋斗才出现了软件行业的繁荣的景象,其中已有不少成为大师级人物。今天我们站在伟人的肩膀上,自然会有不少的优势,但不要忘了,要在对技术的认知方面有......
  • poj 1469 COURSES----二分图
    二分图的最大匹配,模板。。#include<stdio.h>#include<string.h>booledge[110][310],visited[310];intcx[110],cy[310];intn,m;intpath(intu){ intv; for(intv=1;v<=m;v++) if(edge[u][v]&&!visited[v]){ visited[v]=1; if(cy[v]==-1||......
  • poj 1325 Machine Schedule---二分图求最小顶点覆盖
    二分图求最小顶点覆盖。。注意本题说,机器开始在0开始,所以就是默认和0相连的job已经被完成了,所以我是从1开始扫的点正常的话,要将edge【】【】和0相连的边值赋为0,表示该job已经被完成。。。#include<stdio.h>#include<string.h>booledge[110][110],visited[110];intcx[110],cy......
  • 折半查找
                   ......