注意,int数组要先排序
package com.lhkj.dao;
/**
* 前提int数组是升序排列
* 可以将数组先排序
* 推荐冒泡
* @author 李晗
*
*/
public class test{
public static int find(int[] data,int goal,int left,int right){
int mid = (left+right)/2 ;
if(left>right){
return -1 ;
}
if(goal==data[mid]){
return mid ;
}
else if(goal<data[mid]){
//注意right = mid -1 ;
return find(data,goal,left,mid-1);
}
else if(goal>data[mid]){
return find(data,goal,mid+1,right);
}
return -1 ;
}
public static void main(String[] args){
int[] data = new int[]{1,2,4,6,7};
int result =find(data,6,0,data.length-1) ;
System.out.println(result);
}
}
运行结果
3
即在第三个位置
备注资料:
1、二分查找(Binary Search)
二分查找又称折半查找,它是一种效率较高的查找方法。
二分查找要求:线性表是有序表,即表中结点按关键字有序,并且要用向量作为表的存储结构。不妨设有序表是递增有序的。
2、二分查找的基本思想
二分查找的基本思想是:(设R[low..high]是当前的查找区间)
(1)首先确定该区间的中点位置:
(2)然后将待查的K值与R[mid].key比较:若相等,则查找成功并返回此位置,否则须确定新的查找区间,继续二分查找,具体方法如下:
①若R[mid].key>K,则由表的有序性可知R[mid..n].keys均大于K,因此若表中存在关键字等于K的结点,则该结点必定是在位置mid左边的子表R[1..mid-1]中,故新的查找区间是左子表R[1..mid-1]。
②类似地,若R[mid].key<K,则要查找的K必在mid的右子表R[mid+1..n]中,即新的查找区间是右子表R[mid+1..n]。下一次查找是针对新的查找区间进行的。
因此,从初始的查找区间R[1..n]开始,每经过一次与当前查找区间的中点位置上的结点关键字的比较,就可确定查找是否成功,不成功则当前的查找区间就缩小一半。这一过程重复直至找到关键字为K的结点,或者直至当前的查找区间为空(即查找失败)时为止。
分享到:
相关推荐
Java二分查找递归算法
以下是一个简单的 Java 二分查找算法示例: ```java public class BinarySearchDemo { public static int binarySearch(int[] array, int target) { if (array == null || array.length == 0) { return -1; } ...
### Java二分查找算法知识点详解 #### 一、二分查找算法概述 二分查找算法是一种在有序数组中查找特定元素的搜索算法。其工作原理是通过将目标值与数组中间元素进行比较来缩小搜索范围,进而达到快速查找的目的。...
二分查找:分别使用Java和Python实现二分查找算法 二分查找:分别使用Java和Python实现二分查找算法 二分查找:分别使用Java和Python实现二分查找算法 二分查找:分别使用Java和Python实现二分查找算法 二分查找:...
一、Java 二分查找算法的原理 二分查找的原理是将数组分成两个部分,然后在其中一个部分继续进行搜索。假设我们要在数组 `a` 中搜索某个元素 `key`,我们可以将数组分成两个部分,左半部分的元素都小于或等于 `key`...
通过学习二分查找算法,不仅可以提高在有序数据集中的搜索效率,而且对于理解和掌握其他更复杂的算法,如归并排序、堆排序等,也有很大帮助。在实际开发中,尤其是在大数据处理、数据库查询等领域,二分查找是不可或...
以下是一个简单的Java二分查找的示例代码: ```java public class BinarySearchDemo { public static int binarySearch(int[] array, int target) { int left = 0; int right = array.length - 1; while (left...
以下是一个简单的Java二分查找法实现,假设数组已经排序: ```java public class MyBinary { public static int binarySearch(int[] array, int target) { int low = 0; int high = array.length - 1; while ...
经典Java笔试算法解析和代码:二分查找.zip 经典Java笔试算法解析和代码:二分查找.zip 经典Java笔试算法解析和代码:二分查找.zip 经典Java笔试算法解析和代码:二分查找.zip 经典Java笔试算法解析和代码:二分查找...
二分查找算法是一种高效的数据搜索方法,主要应用于已排序的序列。它的基本思想是通过不断地将待搜索区域减半来快速定位目标值。这个过程基于分治策略,将大问题分解为更小的子问题来解决。在二分查找算法中,每次...
根据给定的文件信息,我们可以总结出几种在Java中实现的...以上算法在Java中的实现涵盖了从简单到复杂的查找技术,包括线性查找、二分查找以及基于树的数据结构查找,为程序员提供了多种选择,以适应不同场景下的需求。
* 简单实现:二分查找算法的实现非常简单,只需要使用简单的比较和赋值操作。 缺点 二分查找算法也存在一些缺点: * 需要有序数组:二分查找算法要求数组是有序的,如果数组是无序的,需要先对数组进行排序。 * ...
分别用递归和非递归方法实现二分查找算法 的完整程序,indexof()返回的是循环实现的二分法查找,getindex()实现的是递归算法实现的二分法查找。
Java二分查找算法实现代码实例 Java二分查找算法实现代码实例主要介绍了Java中的二分查找算法实现代码实例,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值。需要的朋友可以参考下。...
二分查找算法是一种在有序数组中查找特定元素的搜索算法,具有较高的效率。它的核心思想是利用数组的中间元素作为参照,通过比较目标值与中间元素的关系,不断缩小搜索范围,直到找到目标值或者确定目标值不存在。在...
该工具包含有Java一些比较常见的排序算法和查找算法。 排序算法包括:冒泡排序、选择排序 、插入排序、希尔排序、快速排序、归并排序、基数...查找算法包括:线性查找、二分查找、插值查询、斐波那契(黄金分割法)、
二分查找算法与冒泡排序算法是计算机科学中两种基础且重要的算法,它们在数据处理和数组操作中扮演着至关重要的角色。 首先,我们来详细探讨递归二分查找算法。二分查找,也称为折半查找,是一种在有序数组中查找...
2. **二分查找**:虽然通常二分查找用于有序数组,但在这个问题中,由于数组是乱序的,直接使用二分查找并不适用。然而,我们可以稍作变通,先对数组排序,然后使用二分查找。排序后的时间复杂度为O(n log n),排序...
在Java编程中,文件读取、数组操作、选择排序以及二分查找是常见的编程任务,它们涉及了IO流、数据结构和算法等多个方面。以下是这些知识点的详细解释: 1. **文件读取**:Java提供了丰富的IO流类库用于读取文件。...
本代码是利用java语言实现基本数据查询功能,实现算法为二分查找法