(8)《数据结构与算法》之查找算法

本文介绍了在Java中实现数据结构与算法中的四种查找算法:顺序查找、二分查找、插值查找和斐波那契查找。详细讲解了每种查找方法的原理和实现,包括查找过程中如何确定目标值并返回其下标,以及在遇到多个匹配项时如何处理。同时,文章提供了具体的代码示例和应用场景。
摘要由CSDN通过智能技术生成

在java中,我们常见的查找有四种

  1. 顺序查找,也叫线性查找
  2. 二分查找,也叫折半查找
  3. 插值查找
  4. 斐波那契查找

我们将一一介绍着四种查找方式的思想以及程序的实现。


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.二分查找

二分查找的查找过程:先确定待查找记录所在的范围(区间),然后逐步缩小范围直到找到或找不到该记录为止。
接下来我们将对这个查找过程进行分析和代码实现:
思路

  1. 我们要新建一个有序数组arr
  2. 确定该数组中间值的下标 mid = (left + right) / 2;
  3. 让需要查找的数findVal 和中间值 arr[mid] 比较
    3.1 findVal > arr[mid], 说明你要查找的数在mid的右边,因此需要 递归的向查找
    3.2 findVal < arr[mid], 说明你要查找的数在mid的左边,因此需要 递归的向查找
    3.3 findVal = arr[mid], 说明你找到了,就返回mi
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值