复习之二分查找
来源:互联网 发布:阿里云带宽怎么升级 编辑:程序博客网 时间:2024/04/27 21:28
二分查找又称折半查找
前提条件: 1 采用顺序存储结构 ;2 待查找序列是有序的
如果待查找序列是有序的,则二分查找是最好的查找算法。
不多说,上代码
普通实现
package com.lyj.search;public class BinarySearch { /** * @param args */ public static void main(String[] args) { int[] array = { 1, 4, 12, 17, 20, 25, 34, 40 }; int index = normalBinarySearch(array, 25); System.out.println("index: " + index); } private static int normalBinarySearch(int[] array, int target) { // 确定上下界 int lower = 0; int upper = array.length - 1; while (lower <= upper) { // 确定中间位置 int mid = (lower + upper) / 2; if (target == array[mid]) { return mid; } else if (target < array[mid]) { upper = mid - 1; } else { lower = mid + 1; } } // 没有目标值返回-1 return -1; }}
递归实现
package com.lyj.search;public class BinarySearch { /** * @param args */ public static void main(String[] args) { int[] array = { 1, 4, 12, 17, 20, 25, 34, 40 }; int index = recursionBinarySearch(array, 0, array.length - 1, 25); System.out.println("index: " + index); } private static int recursionBinarySearch(int[] array, int lower, int upper, int target) { if (lower <= upper) { int mid = (lower + upper) / 2; if (target == array[mid]) { return mid; } else if (target < array[mid]) { return recursionBinarySearch(array, lower, mid - 1, target); // 这里要return } else { return recursionBinarySearch(array, mid + 1, upper, target); // 这里要return } } return -1; }}
- 复习之二分查找
- 算法复习之二分查找
- 复习数据结构----二分查找算法
- 查找之二分查找
- 查找之二分查找
- 查找之二分查找
- 个人算法复习笔记1-二分查找
- 数据结构复习2.Binary Search二分查找
- java基础复习--数组的二分查找
- 查找算法之二分查找
- 查找算法之二分查找
- 查找之二 , 二分查找
- 查找算法之二分查找
- 查找算法之二分查找
- 查找算法之二分查找
- 查找算法之二分查找
- 查找算法之二分查找
- 查找算法之二分查找
- 联想Y460 XP下独显叹号
- 记录。
- 用路由器连接两台电脑如何设置
- 树遍历相关算法
- ZOJ 2314 Reactor Cooling 无源汇上下界可行流
- 复习之二分查找
- 堆和栈的区别
- 按行合并两个sql的查询结果
- 高中数学公式
- An incompatible version 1.1.14 of the APR based Apache Tomcat Native libra 警告
- svn 常用命令
- 中国航天科工集团与中国航天科技集团区别
- CentOS 6.0 gcc-c++
- 温州动车事故调查组专家称设备技术没问题