首先说说二分查找法。

二分查找法是对一组有序的数字中进行查找,传递相应的数据,进行比较查找到与原数据相同的数据,查找到了返回1,失败返回对应的数组下标。

采用非递归方式完成二分查找法。java代码如下所示。

[java] view plain copy print?

  1. /*

  2. * 非递归二分查找算法

  3. * 参数:整型数组,需要比较的数.

  4. */

  5. public static int binarySearch(Integer[]srcArray,int des){

  6. //第一个位置.

  7. int low=0;

  8. //最高位置.数组长度-1,因为下标是从0开始的.

  9. int high=srcArray.length-1;

  10. //当low"指针"和high不重复的时候.

  11. while(low<=high){

  12. //中间位置计算,low+ 最高位置减去最低位置,右移一位,相当于除2.也可以用(high+low)/2

  13. int middle=low+((high-low)>>1);

  14. //与最中间的数字进行判断,是否相等,相等的话就返回对应的数组下标.

  15. if(des==srcArray[middle]){

  16. return middle;

  17. //如果小于的话则移动最高层的"指针"

  18. }else if(des<srcArray[middle]){

  19. high=middle-1;

  20. //移动最低的"指针"

  21. }else{

  22. low=middle+1;

  23. }

  24. }

  25. return-1;

  26. }

  27. }

采用递归方式完成二分查找算法。代码如下所示。

[java] view plain copy print?

  1. /**

  2. * 递归方法实现二分查找法.

  3. * @param Array数组

  4. * @param low 数组第一位置

  5. * @param high 最高

  6. * @param key 要查找的值.

  7. * @return 返回值.

  8. */

  9. int BinSearch(int Array[],int low,int high,int key)

  10. {

  11. if (low<=high)

  12. {

  13. int mid = (low+high)/2;

  14. if(key == Array[mid])

  15. return mid;

  16. else if(key<Array[mid])

  17. //移动low和high

  18. return BinSearch(Array,low,mid-1,key);

  19. else if(key>Array[mid])

  20. return BinSearch(Array,mid+1,high,key);

  21. }

  22. else

  23. return -1;

  24. }

递归思想会被经常用到,更加突出了编程解决问题的高效。

转载于:https://blog.51cto.com/8023java/1826305

二分查找算法(递归与非递归两种方式)相关推荐

  1. 【数据结构与算法】一篇文章彻底搞懂二分查找(思路图解+代码优化)两种实现方式,递归与非递归

    1.二分查找是什么? 二分查找也称折半查找,是一种效率较高的查找方式.但是,二分查找要求线性表为顺序存储结构且表按关键字有序排列. 时间复杂度:O(log2n) 2.二分查找的思路分析 便于叙述,笔者 ...

  2. 二分查找算法(非递归)

    1.二分查找算法(非递归)介绍 前面我们讲过了二分查找算法,是使用递归的方式,下面我们讲解二分查找算法的非递归方式 二分查找法只适用于从有序的数列中进行查找(比如数字和字母等),将数列排序后再进行查找 ...

  3. Java 二分查找算法及效率比较

    1.前提:二分查找的前提是需要查找的数组必须是已排序的,我们这里的实现默认为升序 2.原理:将数组分为三部分,依次是中值(所谓的中值就是数组中间位置的那个值)前,中值,中值后:将要查找的值和数组的中值 ...

  4. python二分查找时间复杂度_二分查找算法的时间复杂度计算(logN)

    二分查找算法的时间复杂度计算(logN) 马富天 2019-08-10 20:25:24 54 [摘要]二分查找算法是对顺序查找算法的优化,二分查找算法的前提是数列是一个有序数列,递增或者递减,本文就 ...

  5. 二分查找算法的两种实现方式:非递归实现和递归实现

    二分查找的条件是对一组有序数组的查找,这一点很容易忘记,在使用二分查找的时候先要对数组进行排序. 先说一下二分查找的思路:一个有序数组,想要查找一个数字key的下标,首先算出中间下标mid,利用mid ...

  6. 二分查找算法(递归+非递归)

    二分算法步骤描述 前提:有序数组中查找关键词所在的位置 ① 首先确定整个查找区间的中间位置 mid = strat+(end-strat)/2 ② 用待查关键字key值与中间位置的关键字值进行比较: ...

  7. 算法006:二分查找 递归、非递归

    题目: 已知一个有序数组arr 给定需要搜索的元素,返回索引,若无则返回-1思路: 递归和非递归 1.代码如下 BinSearch .java: package com.yuhl.right;/*** ...

  8. 二分查找算法递归实现

    二分查找(Binary Search),又称折半查找,是一种效率较高的查找算法.折半查找需要线性表采用顺序存储结构,即查找的对象必须是一个有序序列.如{1,2,3,4,5...},{10 ,8,6,4 ...

  9. 二分查找(递归和非递归)

    二分算法步骤描述 前提:有序数组中查找关键词所在的位置 ① 首先确定整个查找区间的中间位置 mid = strat+(end-strat)/2 ② 用待查关键字key值与中间位置的关键字值进行比较: ...

最新文章

  1. 程序员过年被亲戚鄙视:月薪1万5很一般,在大城市很难养活自己吧?
  2. phpMyAdmin操作之改管理员密码
  3. 一些有关使用EF的错误用法展开的思考
  4. 拥有一个高性能低延时数据库是什么样的体验?
  5. NFS exports命令
  6. go interface 转 string_深入理解Go的interface内部执行原理
  7. 查看linux的机器内存大小,linux 查看机器内存方法 (free命令)
  8. mysql省市区三级联动数据库的源码(一)
  9. 第一次注册csdn博客
  10. Mac idea激活jrebel
  11. 沙普利算法java实现_Java实现婚姻稳定匹配Gale- Shapley算法
  12. macos复制粘贴快捷键 快速_MacOS中复制和粘贴快捷键说明,及常见的各种快捷键整理大全...
  13. in vivo-in vitro-ex vivo三者的区别
  14. jzoj. 1285. 奶酪厂
  15. C语言C++图形库---贪吃蛇大作战【附源码】
  16. 【论文阅读|深读】LINE: Large-scale Information Network Embedding
  17. C语言猜字游戏---翁凯
  18. 专访扎克伯格: 万字解读Facebook为何将转型为元宇宙公司
  19. IDEA Git操作(三)使用 cherry-pick、交互式 rebase 自由修改提交树
  20. 校招选择题汇总【图形推理(3)】含答案解析

热门文章

  1. qt获取开发板ip地址_qt获取网络ip地址的类
  2. property、staticmethod、classmethod与__str__的用法
  3. linux命令重定向、、 1、 2、 1、 2、
  4. dropout比率最好的设置为0.5,因为随机生成的网络结构最多
  5. 西安后宰门小学_陈洪杰:“数学魔术”课程校本化的价值与意义 || 为西安后宰门小学点个赞...
  6. eclipse lombok插件安装_如果你是Java架构师或项目经理,项目技术会允许使用Lombok吗?
  7. 不同坐标系下角速度_坐标系统及常见坐标系
  8. 条形图坐标轴_手把手教你用Excel绘图 | 双轴簇状条形图
  9. 还不知道要看什么小说嘛?爬取小说网站前10页的小说数据分析一波
  10. 网页设计简约_简约设计指南