二分查找排序算法
编程技术  /  houtizong 发布于 3年前   590
publicstaticint binarySearch2(int[] srcArray,int des) throws Exception{int beginIndex = 0;int endIndex = srcArray.length-1;int middleIndex = beginIndex+((endIndex-beginIndex)>>1);while(srcArray[middleIndex] != des && endIndex > beginIndex && (endIndex-1)>beginIndex){ if(srcArray[middleIndex] < des){ beginIndex = middleIndex; }elseif(srcArray[middleIndex] > des){ endIndex = middleIndex; } middleIndex = beginIndex+((endIndex-beginIndex)>>1); } if(srcArray[middleIndex] == des){ return middleIndex; //表示找到了,返回该值的下标 }else{ thrownew Exception("没有找到"); //表示没有找到 }}上面这是自己根据对二分查找算法原理的理解写出来的代码。
下面的是摘自己网上的写法:
public static int binarySearch3(int[] srcArray,int des) throws Exception{int beginIndex = 0;int endIndex = srcArray.length-1;while(beginIndex <= endIndex){int middleIndex = beginIndex+((endIndex-beginIndex)>>1);if(srcArray[middleIndex] < des){beginIndex = middleIndex+1;}else if(srcArray[middleIndex] > des){endIndex = middleIndex-1;}else{return middleIndex;}}throw new Exception("没有找到");//表示没有找到}
请勿发布不友善或者负能量的内容。与人为善,比聪明更重要!
技术博客集 - 网站简介:
前后端技术:
后端基于Hyperf2.1框架开发,前端使用Bootstrap可视化布局系统生成
网站主要作用:
1.编程技术分享及讨论交流,内置聊天系统;
2.测试交流框架问题,比如:Hyperf、Laravel、TP、beego;
3.本站数据是基于大数据采集等爬虫技术为基础助力分享知识,如有侵权请发邮件到站长邮箱,站长会尽快处理;
4.站长邮箱:[email protected];
文章归档
文章标签
友情链接