1.二分查找步骤描述
(1)首先确定整个查找区间的中间位置 mid = ( left + right )/ 2
(2)用待查关键字值与中间位置的关键字值进行比较;
若相等,则查找成功
若大于,则在后(右)半个区域继续进行折半查找
若小于,则在前(左)半个区域继续进行折半查找
(3)对确定的缩小区域再按折半公式,重复上述步骤。
一、源码特点1、采用典型的三层架构技术进行开发,作品非常不错,功能很全面,欢迎下载学习交流二、功能介绍本源码是一个购物网站源码。分为前台用户界面和后台管理员界面,分别实现不同功能。三、菜单功能前台用户功能1、主页:显示主页面2、鞋子:鞋子所有品牌及相关信息3、手机数码:数码品牌及相关信息4、护肤品:所有品牌及相关信息5、新闻资讯:本页资讯;行业资讯6、我的账户;我的收藏;我的购物车;我的评论;退出
1
最后,得到结果:要么查找成功, 要么查找失败。折半查找的存储结构采用一维数组存放。 折半查找算法举例
2.要求
(1)必须采用顺序存储结构。
(2)必须按关键字大小有序排列。
3.实例
public class Demo {
public static void main(String[] args) {
int[] arr={-1,0,3,5,9,12};//查找的数组
int searchNum=13;//查找的目标数
Arrays.sort(arr);
int resultOne=binarySearchOne(arr,searchNum,0,arr.length-1);
System.out.println(resultOne);
int resultTwo=binarySearchTwo(arr,searchNum);
System.out.println(resultTwo);
}
/**
* 递归实现
* @param arr
* @param searchNum
* @param start
* @param end
* @return
*/
public static int binarySearchOne(int[] arr,int searchNum,int start,int end){
if(start>end)
return -1;
int middle=(start+end)/2;
if(searchNum<arr[middle])
return binarySearchOne(arr,searchNum,start,middle-1);
else if(searchNum>arr[middle])
return binarySearchOne(arr,searchNum,middle+1,end);
else
return middle;
}
/**
* 非递归实现
* @param arr
* @param searchNum
* @return
*/
private static int binarySearchTwo(int[] arr, int searchNum) {
int start=0;
int end=arr.length-1;
while(start<=end){
int middle=(start+end)/2;
if(searchNum<arr[middle])
end=middle-1;
else if(searchNum>arr[middle])
start=middle+1;
else
return middle;
}
return -1;
}
}以上就是Java的二分查找实现原理及代码实现的详细内容,更多请关注php中文网其它相关文章!
java怎么学习?java怎么入门?java在哪学?java怎么学才快?不用担心,这里为大家提供了java速学教程(入门到精通),有需要的小伙伴保存下载就能学习啦!
Copyright 2014-2025 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号