Java数组查找技巧

在Java中,数组是一种非常常用的数据结构。在开发中,经常需要对数组进行查找。因此,在本文中,将从多个方面详细阐述Java数组查找技巧。

一、线性查找

线性查找是一种基本的查找方法,也称为顺序查找。顾名思义,它的查找方式就是从数组的头开始,每次逐个元素进行比较,并且在相应的位置找到目标值时返回。这种查找方式适用于无序数组。

/**
 * 线性查找
 * @param arr 数组
 * @param key 待查找关键字
 * @return 返回查找到的位置,未找到返回-1
 */
public static int linearSearch(int[] arr, int key) {
    for (int i = 0; i < arr.length; i++) {
        if (arr[i] == key) {
            return i;
        }
    }
    return -1;
}

二、二分查找

二分查找也称为折半查找,适用于有序数列。它的查找方式是将有序数组分为左右两个部分,每次比较中间位置的元素值,如果匹配则返回,否则缩小查找范围,重复此步骤,直到找到目标值或查找范围为空。

/**
 * 二分查找
 * @param arr 数组
 * @param key 待查找关键字
 * @return 返回查找到的位置,未找到返回-1
 */
public static int binarySearch(int[] arr, int key) {
    int low = 0;
    int high = arr.length - 1;
    while (low <= high) {
        int mid = (low + high) / 2;
        if (arr[mid] == key) {
            return mid;
        } else if (arr[mid] < key) {
            low = mid + 1;
        } else {
            high = mid - 1;
        }
    }
    return -1;
}

三、插值查找

插值查找是对二分查找的改进,适用于数值分布比较均匀的有序条件。它的查找方式是根据要查找的关键值key与数组的边界值arr[low]和arr[high]以及中间位置arr[mid]的关系,计算mid的值并且从mid位置开始逐步找到目标值位置。

/**
 * 插值查找
 * @param arr 数组
 * @param key 待查找关键字
 * @return 返回查找到的位置,未找到返回-1
 */
public static int interpolationSearch(int[] arr, int key) {
    int low = 0;
    int high = arr.length - 1;
    while (low <= high) {
        int mid = low + (high - low) * (key - arr[low]) / (arr[high] - arr[low]);
        if (arr[mid] == key) {
            return mid;
        } else if (arr[mid] < key) {
            low = mid + 1;
        } else {
            high = mid - 1;
        }
    }
    return -1;
}

四、哈希查找

哈希查找是通过建立一个哈希表来实现查找的方式。哈希表的建立是通过对关键字进行哈希函数的计算,将关键字映射为数组的下标,然后将该关键字存储在对应的数组位置上。在查找时,根据哈希函数计算关键字的位置,判断该位置上的关键字是否匹配,如果匹配,则返回对应数组下标,否则在哈希表中继续查找。

/**
 * 哈希查找
 * @param arr 数组
 * @param key 待查找关键字
 * @return 返回查找到的位置,未找到返回-1
 */
public static int hashSearch(int[] arr, int key) {
    Map map = new HashMap();
    for (int i = 0; i < arr.length; i++) {
        map.putIfAbsent(arr[i], i);
    }
    return map.getOrDefault(key, -1);
}

五、小结

以上就是几种常见的Java数组查找技巧。选择适合自己的查找方法,可以提高查找效率,更好地完成任务。

原创文章,作者:BNNZ,如若转载,请注明出处:https://www.506064.com/n/149145.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
BNNZBNNZ
上一篇 2024-11-04 17:51
下一篇 2024-11-04 17:51

相关推荐

  • Java JsonPath 效率优化指南

    本篇文章将深入探讨Java JsonPath的效率问题,并提供一些优化方案。 一、JsonPath 简介 JsonPath是一个可用于从JSON数据中获取信息的库。它提供了一种DS…

    编程 2025-04-29
  • java client.getacsresponse 编译报错解决方法

    java client.getacsresponse 编译报错是Java编程过程中常见的错误,常见的原因是代码的语法错误、类库依赖问题和编译环境的配置问题。下面将从多个方面进行分析…

    编程 2025-04-29
  • Java腾讯云音视频对接

    本文旨在从多个方面详细阐述Java腾讯云音视频对接,提供完整的代码示例。 一、腾讯云音视频介绍 腾讯云音视频服务(Cloud Tencent Real-Time Communica…

    编程 2025-04-29
  • Java Bean加载过程

    Java Bean加载过程涉及到类加载器、反射机制和Java虚拟机的执行过程。在本文中,将从这三个方面详细阐述Java Bean加载的过程。 一、类加载器 类加载器是Java虚拟机…

    编程 2025-04-29
  • 使用vscode建立UML图的实践和技巧

    本文将重点介绍在使用vscode在软件开发中如何建立UML图,并且给出操作交互和技巧的指导。 一、概述 在软件开发中,UML图是必不可少的重要工具之一。它为软件架构和各种设计模式的…

    编程 2025-04-29
  • Java Milvus SearchParam withoutFields用法介绍

    本文将详细介绍Java Milvus SearchParam withoutFields的相关知识和用法。 一、什么是Java Milvus SearchParam without…

    编程 2025-04-29
  • Python导入数组

    本文将为您详细阐述Python导入数组的方法、优势、适用场景等方面,并附上代码示例。 一、numpy库的使用 numpy是Python中一个强大的数学库,其中提供了非常丰富的数学函…

    编程 2025-04-29
  • Java 8中某一周的周一

    Java 8是Java语言中的一个版本,于2014年3月18日发布。本文将从多个方面对Java 8中某一周的周一进行详细的阐述。 一、数组处理 Java 8新特性之一是Stream…

    编程 2025-04-29
  • Python返回数组:一次性搞定多种数据类型

    Python是一种多用途的高级编程语言,具有高效性和易读性的特点,因此被广泛应用于数据科学、机器学习、Web开发、游戏开发等各个领域。其中,Python返回数组也是一项非常强大的功…

    编程 2025-04-29
  • Java判断字符串是否存在多个

    本文将从以下几个方面详细阐述如何使用Java判断一个字符串中是否存在多个指定字符: 一、字符串遍历 字符串是Java编程中非常重要的一种数据类型。要判断字符串中是否存在多个指定字符…

    编程 2025-04-29

发表回复

登录后才能评论