在java中,我们常见的查找有四种
- 顺序查找,也叫线性查找
- 二分查找,也叫折半查找
- 插值查找
- 斐波那契查找
我们将一一介绍着四种查找方式的思想以及程序的实现。
1.顺序查找
顺序查找 的查找过程为:从数组的第一个元素开始,逐个将要查找的关键字和数组中的元素进行比较,若存在相等,则返回对应的下标。反之,若至最后一个元素,其关键字和元素都不相等,则表明数组中不存在要查找的数,查找不成功
举例说明:
有一个数列: {1,8, 10, 89, 1000, 1234} ,判断数列中是否包含数字8;要求: 如果找到了,就提示找到,并给出下标值。
public class seqSearch {
public static void main(String[] args) {
//定义数组arr
int[] arr = {1,8, 10, 89, 1000, 1234};
//定义下标
int index = seqSearch(arr, 8);
//当下标为-1时,说明要查找的数不存在
if (index == -1) {
System.out.println("不存在");
} else {
System.out.println("下标为:" + index);
}
}
public static int seqSearch(int[] arr, int value) {
for (int i = 0; i < arr.length; i++) {
if (arr[i] == value ) {
return i;
}
}
//因为下标数值总是>= 0,所以,当要查找的数不存在时,返回-1即可
return -1;
}
}
扩展 : 假如我们要查的数在数组中存在两个及两个以上,我们怎么把所有满足条件的元素下标输出呢?
思考: 这个问题的难点在于我们并不知道数组有多大,以及要查的数到底有多少个,所以无法新建一个新的数组来保存满足条件的下标。所以我们使用ArrayList 来存储保存满足条件的下标。
import java.util.ArrayList;
public class seqSearch {
public static void main(String[] args) {
int[] arr = {1, 9, 11, 11, 52, 65, -4};
ArrayList<Integer> arrayList = seqSearch(arr, 11);
//当没有查找到时,则arrayList中则没有下标值
System.out.println("arrayList:" + arrayList);
}
public static ArrayList<Integer> seqSearch(int[] arr, int value) {
ArrayList<Integer> arrayList = new ArrayList<Integer>();
for (int i = 0; i < arr.length; i++) {
if (arr[i] == value ) {
//将满足条件的下标放入arrayList中
arrayList.add(i);
}
}
return arrayList;
}
}
2.二分查找
二分查找的查找过程:先确定待查找记录所在的范围(区间),然后逐步缩小范围直到找到或找不到该记录为止。
接下来我们将对这个查找过程进行分析和代码实现:
思路:
- 我们要新建一个有序数组arr
- 确定该数组中间值的下标 mid = (left + right) / 2;
- 让需要查找的数findVal 和中间值 arr[mid] 比较
3.1 findVal > arr[mid], 说明你要查找的数在mid的右边,因此需要 递归的向右查找
3.2 findVal < arr[mid], 说明你要查找的数在mid的左边,因此需要 递归的向左查找
3.3 findVal = arr[mid], 说明你找到了,就返回mi