java二分法查找怎么实现
Java  /  管理员 发布于 8年前   160
java二分法查找怎么实现
BinarySearch
二分法查找,顾名思义就是要将数据每次都分成两份然后再去找到你想要的数据,
我们可以这样去想,二分法查找很类似与我们平时玩的猜价格游戏,当你报出一个价格时裁判会告诉你价格相对于真实值的高低,倘若是低了那我们一定会再说出一个略高的价格,反之亦然。
(相关视频教程分享:java视频教程)
在二分法查找时要求传入的数据必须已经有序,假设现在为升序,然后每次将所寻找的值与中间值(数组左边界+(右边界-左边界)/2)作比较,大了则去寻找中间值左侧数据,小则寻找中间值右侧数据。
public class BinarySearch {//进行二分法查找的前提是数组已经有序!public static int rank(int key,int nums[]){//查找范围的上下界int low=0;int high=nums.length-1;//未查找到的返回值int notFind=-1;while(low<=high){//二分中点=数组左边界+(右边界-左边界)/2//整数类型默认取下整int mid=low+(high-low)/2;//中间值是如果大于keyif(nums[mid]>key){//证明key在[low,mid-1]这个区间//因为num[mid]已经判断过了所以下界要减一high=mid-1;}else if(nums[mid]<key){//证明key在[mid+1,high]这个区间//同样判断过mid对应的值要从mid+1往后判断low=mid+1;}else{//查找成功return mid;}}//未成功return notFind;}public static void main(String[] args) {System.out.println("请输入数据数量:");Scanner scanner=new Scanner(System.in);int amount=scanner.nextInt();int num;int nums[]=new int[amount];int i=0;while(i<amount){nums[i]=scanner.nextInt();i++;}Arrays.sort(nums);System.out.println("请输入想要查找的值");int key=scanner.nextInt();int answer=rank(key,nums);if(answer!=-1){System.out.println("所查找的数据存在:"+nums[answer]);}else{System.out.println("您所查找的数据不存在");}} }
更多java教程,请关注Java教程栏目。
以上就是java二分法查找怎么实现的详细内容,更多请关注其它相关文章!
122 在
学历:一种延缓就业设计,生活需求下的权衡之选中评论 工作几年后,报名考研了,到现在还没认真学习备考,迷茫中。作为一名北漂互联网打工人..123 在
Clash for Windows作者删库跑路了,github已404中评论 按理说只要你在国内,所有的流量进出都在监控范围内,不管你怎么隐藏也没用,想搞你分..原梓番博客 在
在Laravel框架中使用模型Model分表最简单的方法中评论 好久好久都没看友情链接申请了,今天刚看,已经添加。..博主 在
佛跳墙vpn软件不会用?上不了网?佛跳墙vpn常见问题以及解决办法中评论 @1111老铁这个不行了,可以看看近期评论的其他文章..1111 在
佛跳墙vpn软件不会用?上不了网?佛跳墙vpn常见问题以及解决办法中评论 网站不能打开,博主百忙中能否发个APP下载链接,佛跳墙或极光..
Copyright·© 2019 侯体宗版权所有·
粤ICP备20027696号