java递归实现二分查找算法
2016-07-14 17:30
681 查看
只做知识点记录,不做别的.
package test; public class Bipartite { public static void main(String[] args) { int result = 0; try { result = bipartiteFind(16,arrs); } catch (Exception e) { e.printStackTrace(); } if(result != -1){ System.out.println("index:"+result+" 值:"+arrs[result]); }else{ System.err.println("没有找到该数据"); } } static int[] arrs = new int[]{1,2,3,4,5,7,8,9,10,12,13,15,16}; /** * 二分查找 * @return * @throws Exception */ static int bipartiteFind(int x,int[] arr) throws Exception{ if(arr == null || arr.length<=0) throw new Exception("数组不能为空,长度不能小于等0"); return find(arr,0,arrs.length,x); } private static int find(int arrs[],int start,int end,int x){ if(start > end) return -1; int index = (end-start) / 2 + start; if(arrs[index] == x) return index; else if(arrs[index] > x) return find(arrs,start,index-1,x); else if(arrs[index] < x) return find(arrs,index+1,end,x); return -1; } }
相关文章推荐
- java对世界各个时区(TimeZone)的通用转换处理方法(转载)
- java-注解annotation
- java-模拟tomcat服务器
- java-用HttpURLConnection发送Http请求.
- java-WEB中的监听器Lisener
- Android IPC进程间通讯机制
- Android Native 绘图方法
- Android java 与 javascript互访(相互调用)的方法例子
- 介绍一款信息管理系统的开源框架---jeecg
- 聚类算法之kmeans算法java版本
- java实现 PageRank算法
- PropertyChangeListener简单理解
- c++11 + SDL2 + ffmpeg +OpenAL + java = Android播放器
- 插入排序
- 冒泡排序
- 堆排序
- 快速排序
- 二叉查找树