二分查找算法(递归与非递归两种方式)
首先说说二分查找法。
二分查找法是对一组有序的数字中进行查找,传递相应的数据,进行比较查找到与原数据相同的数据,查找到了返回1,失败返回对应的数组下标。
采用非递归方式完成二分查找法。java代码如下所示。
[java] view plain copy print?
/*
* 非递归二分查找算法
* 参数:整型数组,需要比较的数.
*/
public static int binarySearch(Integer[]srcArray,int des){
//第一个位置.
int low=0;
//最高位置.数组长度-1,因为下标是从0开始的.
int high=srcArray.length-1;
//当low"指针"和high不重复的时候.
while(low<=high){
//中间位置计算,low+ 最高位置减去最低位置,右移一位,相当于除2.也可以用(high+low)/2
int middle=low+((high-low)>>1);
//与最中间的数字进行判断,是否相等,相等的话就返回对应的数组下标.
if(des==srcArray[middle]){
return middle;
//如果小于的话则移动最高层的"指针"
}else if(des<srcArray[middle]){
high=middle-1;
//移动最低的"指针"
}else{
low=middle+1;
}
}
return-1;
}
}
采用递归方式完成二分查找算法。代码如下所示。
[java] view plain copy print?
/**
* 递归方法实现二分查找法.
* @param Array数组
* @param low 数组第一位置
* @param high 最高
* @param key 要查找的值.
* @return 返回值.
*/
int BinSearch(int Array[],int low,int high,int key)
{
if (low<=high)
{
int mid = (low+high)/2;
if(key == Array[mid])
return mid;
else if(key<Array[mid])
//移动low和high
return BinSearch(Array,low,mid-1,key);
else if(key>Array[mid])
return BinSearch(Array,mid+1,high,key);
}
else
return -1;
}
递归思想会被经常用到,更加突出了编程解决问题的高效。
转载于:https://blog.51cto.com/8023java/1826305
二分查找算法(递归与非递归两种方式)相关推荐
- 【数据结构与算法】一篇文章彻底搞懂二分查找(思路图解+代码优化)两种实现方式,递归与非递归
1.二分查找是什么? 二分查找也称折半查找,是一种效率较高的查找方式.但是,二分查找要求线性表为顺序存储结构且表按关键字有序排列. 时间复杂度:O(log2n) 2.二分查找的思路分析 便于叙述,笔者 ...
- 二分查找算法(非递归)
1.二分查找算法(非递归)介绍 前面我们讲过了二分查找算法,是使用递归的方式,下面我们讲解二分查找算法的非递归方式 二分查找法只适用于从有序的数列中进行查找(比如数字和字母等),将数列排序后再进行查找 ...
- Java 二分查找算法及效率比较
1.前提:二分查找的前提是需要查找的数组必须是已排序的,我们这里的实现默认为升序 2.原理:将数组分为三部分,依次是中值(所谓的中值就是数组中间位置的那个值)前,中值,中值后:将要查找的值和数组的中值 ...
- python二分查找时间复杂度_二分查找算法的时间复杂度计算(logN)
二分查找算法的时间复杂度计算(logN) 马富天 2019-08-10 20:25:24 54 [摘要]二分查找算法是对顺序查找算法的优化,二分查找算法的前提是数列是一个有序数列,递增或者递减,本文就 ...
- 二分查找算法的两种实现方式:非递归实现和递归实现
二分查找的条件是对一组有序数组的查找,这一点很容易忘记,在使用二分查找的时候先要对数组进行排序. 先说一下二分查找的思路:一个有序数组,想要查找一个数字key的下标,首先算出中间下标mid,利用mid ...
- 二分查找算法(递归+非递归)
二分算法步骤描述 前提:有序数组中查找关键词所在的位置 ① 首先确定整个查找区间的中间位置 mid = strat+(end-strat)/2 ② 用待查关键字key值与中间位置的关键字值进行比较: ...
- 算法006:二分查找 递归、非递归
题目: 已知一个有序数组arr 给定需要搜索的元素,返回索引,若无则返回-1思路: 递归和非递归 1.代码如下 BinSearch .java: package com.yuhl.right;/*** ...
- 二分查找算法递归实现
二分查找(Binary Search),又称折半查找,是一种效率较高的查找算法.折半查找需要线性表采用顺序存储结构,即查找的对象必须是一个有序序列.如{1,2,3,4,5...},{10 ,8,6,4 ...
- 二分查找(递归和非递归)
二分算法步骤描述 前提:有序数组中查找关键词所在的位置 ① 首先确定整个查找区间的中间位置 mid = strat+(end-strat)/2 ② 用待查关键字key值与中间位置的关键字值进行比较: ...
最新文章
- 程序员过年被亲戚鄙视:月薪1万5很一般,在大城市很难养活自己吧?
- phpMyAdmin操作之改管理员密码
- 一些有关使用EF的错误用法展开的思考
- 拥有一个高性能低延时数据库是什么样的体验?
- NFS exports命令
- go interface 转 string_深入理解Go的interface内部执行原理
- 查看linux的机器内存大小,linux 查看机器内存方法 (free命令)
- mysql省市区三级联动数据库的源码(一)
- 第一次注册csdn博客
- Mac idea激活jrebel
- 沙普利算法java实现_Java实现婚姻稳定匹配Gale- Shapley算法
- macos复制粘贴快捷键 快速_MacOS中复制和粘贴快捷键说明,及常见的各种快捷键整理大全...
- in vivo-in vitro-ex vivo三者的区别
- jzoj. 1285. 奶酪厂
- C语言C++图形库---贪吃蛇大作战【附源码】
- 【论文阅读|深读】LINE: Large-scale Information Network Embedding
- C语言猜字游戏---翁凯
- 专访扎克伯格: 万字解读Facebook为何将转型为元宇宙公司
- IDEA Git操作(三)使用 cherry-pick、交互式 rebase 自由修改提交树
- 校招选择题汇总【图形推理(3)】含答案解析
热门文章
- qt获取开发板ip地址_qt获取网络ip地址的类
- property、staticmethod、classmethod与__str__的用法
- linux命令重定向、、 1、 2、 1、 2、
- dropout比率最好的设置为0.5,因为随机生成的网络结构最多
- 西安后宰门小学_陈洪杰:“数学魔术”课程校本化的价值与意义 || 为西安后宰门小学点个赞...
- eclipse lombok插件安装_如果你是Java架构师或项目经理,项目技术会允许使用Lombok吗?
- 不同坐标系下角速度_坐标系统及常见坐标系
- 条形图坐标轴_手把手教你用Excel绘图 | 双轴簇状条形图
- 还不知道要看什么小说嘛?爬取小说网站前10页的小说数据分析一波
- 网页设计简约_简约设计指南