算法-查找算法

下面是使用 Java 实现的四种查找算法

  1. 线性查找(Linear Search)
  2. 二分查找(Binary Search)
  3. 插值查找(Interpolation Search)
  4. 斐波那契查找(Fibonacci Search)

✅ 1. 线性查找(Linear Search)

说明:

从数组的第一个元素开始,逐个比较,直到找到目标值或遍历完整个数组。

Java 实现:

public class LinearSearch {public static int linearSearch(int[] arr, int target) {for (int i = 0; i < arr.length; i++) {if (arr[i] == target) {return i; // 返回索引}}return -1; // 未找到}public static void main(String[] args) {int[] arr = {4, 2, 7, 1, 9, 3};int target = 7;System.out.println("Index of " + target + ": " + linearSearch(arr, target)); // 输出 2}
}

✅ 2. 二分查找(Binary Search)

说明:

适用于有序数组。每次将查找区间缩小一半,效率高,时间复杂度为 O(log n)

Java 实现:

public class BinarySearch {public static int binarySearch(int[] arr, int target) {int left = 0;int right = arr.length - 1;while (left <= right) {int mid = left + (right - left) / 2;if (arr[mid] == target) {return mid;} else if (arr[mid] < target) {left = mid + 1;} else {right = mid - 1;}}return -1;}public static void main(String[] args) {int[] arr = {1, 3, 5, 7, 9, 11};int target = 7;System.out.println("Index of " + target + ": " + binarySearch(arr, target)); // 输出 3}
}

✅ 3. 插值查找(Interpolation Search)

说明:

是对二分查找的优化,适用于数据分布均匀的有序数组。通过插值公式计算中间点,平均性能优于二分查找。

Java 实现:

public class InterpolationSearch {public static int interpolationSearch(int[] arr, int target) {int left = 0;int right = arr.length - 1;while (left <= right && target >= arr[left] && target <= arr[right]) {int pos = left + ((target - arr[left]) * (right - left)) / (arr[right] - arr[left]);if (arr[pos] == target) {return pos;} else if (arr[pos] < target) {left = pos + 1;} else {right = pos - 1;}}return -1;}public static void main(String[] args) {int[] arr = {10, 20, 30, 40, 50, 60, 70, 80, 90, 100};int target = 60;System.out.println("Index of " + target + ": " + interpolationSearch(arr, target)); // 输出 5}
}

✅ 4. 斐波那契查找(Fibonacci Search)

说明:

基于斐波那契数列对数组进行分割,也是一种适用于有序数组的查找算法,平均性能与二分查找相当,但减少除法运算,在某些硬件环境下效率更高。

Java 实现:

public class FibonacciSearch {public static int fibonacciSearch(int[] arr, int target) {int n = arr.length;int[] fib = new int[20];fib[0] = 0;fib[1] = 1;int i = 1;while (fib[i] < n) {fib[++i] = fib[i - 1] + fib[i - 2];}int offset = 0;while (fib[i] > 1) {int k = Math.min(offset + fib[i - 2], n - 1);if (arr[k] < target) {offset = k;fib[i] = fib[i - 1];fib[i - 1] = fib[i - 2];i--;} else if (arr[k] > target) {fib[i] = fib[i - 2];fib[i - 1] = fib[i - 1] - fib[i - 2];i--;} else {return k;}}if (fib[i - 1] == 1 && arr[offset + 1] == target) {return offset + 1;}return -1;}public static void main(String[] args) {int[] arr = {1, 3, 5, 7, 9, 11, 13, 15};int target = 9;System.out.println("Index of " + target + ": " + fibonacciSearch(arr, target)); // 输出 4}
}

✅ 查找算法对比表

查找算法数据要求时间复杂度空间复杂度特点
线性查找无序数组O(n)O(1)简单,适合小数据量
二分查找有序数组O(log n)O(1)高效,常用
插值查找有序数组(分布均匀)O(log log n) ~ O(n)O(1)数据均匀时性能更好
斐波那契查找有序数组O(log n)O(1)避免除法,适合特定环境

✅ 总结

  • 线性查找:最简单,但效率低,适合小数据或无序数组。
  • 二分查找:最常用,适用于有序数组,效率高。
  • 插值查找:适用于数据分布均匀的场景,性能优于二分查找。
  • 斐波那契查找:减少除法操作,适合某些硬件环境,实现稍复杂。

在实际开发中,根据数据是否有序、数据分布、性能需求等选择合适的查找算法。

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。
如若转载,请注明出处:http://www.pswp.cn/news/915036.shtml
繁体地址,请注明出处:http://hk.pswp.cn/news/915036.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

二刷 黑马点评 附近商户

附近商户-GEO数据结构的基本用法 GEO就是Geolocation的简写形式&#xff0c;代表地理坐标 Redis在3.2版本中加入了对GEO的支持&#xff0c;允许存储地理坐标信息&#xff0c;帮助我们根据经纬度来检索数据。常见的命令有&#xff1a;GEOADD&#xff1a;添加一个地理空间信息&am…

【vue-3】深入理解 Vue 3 中的 v-if 指令:条件渲染的艺术

在 Vue.js 的世界中&#xff0c;条件渲染是构建动态界面的核心概念之一。作为 Vue 3 中最常用的指令之一&#xff0c;v-if 提供了强大的能力来控制元素的显示与隐藏。本文将深入探讨 v-if 的工作原理、最佳实践以及它在 Vue 3 中的新特性。 1. 什么是 v-if&#xff1f; v-if 是…

【实时Linux实战系列】实时系统中的内存策略

在实时系统中&#xff0c;内存管理是确保系统性能和稳定性的重要组成部分。实时系统通常需要快速响应和低延迟&#xff0c;因此高效的内存管理策略对于实现这些目标至关重要。实时 Linux 提供了多种内存管理机制&#xff0c;如使用大型页面&#xff08;Huge Pages&#xff09;和…

【C语言进阶】题目练习(2)

目录 题目6:看代码说结果 分析&#xff1a; 答案&#xff1a;255 题目7&#xff1a;猜名次 分析&#xff1a; 题目8&#xff1a;猜凶手 分析&#xff1a; 代码&#xff1a; 题目9&#xff1a;打印杨辉三角 思路: 代码: 题目10&#xff1a;关于指针的选择题 答案&a…

思科NAT综合实验

1 实验拓扑图2实验目的(1)巩固前面实验的配置(2)掌握四种NAT的配置(3)明白四种NAT的区别3实验步骤3.1配置边界路由器和外网路由器的端口IP三个步骤&#xff1a;进入端口 打开端口 配置IP地址和子网掩码interface f0/0 no shutdown ip address 192.168.201.2 255.255.255.03.2配…

VMC850立式加工中心Y轴传动机械结构设计cad【7张】三维图+设计说明书

摘 要 数控机床作为现代工业生产的重要设备&#xff0c;对国民经济的发展有着重要的作用&#xff0c;立式加工中心作为数控加工技术的核心&#xff0c;通过对其研究&#xff0c;可以深入了解数控技术未来的发展方向。本文主要完成了VMC850立式加工中心Y轴的机械传动结构设计&am…

mpiigaze的安装过程一

mpiigaze链接 mpiigaze应该不是作者本人写的&#xff0c;而是社区工作者的杰作&#xff0c;对原论文Appearance-Based Gaze Estimation in the Wild的代码进行的一些复现 1.创建conda环境 2.问题 Building wheels for collected packages: dlibBuilding wheel for dlib (py…

如何将华为文件传输到电脑

在数字管理领域&#xff0c;将华为设备上的文件传输到电脑是高频需求。无论为了备份、缓解手机存储压力&#xff0c;还是跨平台访问&#xff0c;把华为手机连接电脑已成为许多用户的刚需。下面介绍 5 种高效方法&#xff0c;可满足不同场景与偏好&#xff0c;助你轻松完成文件迁…

LP-MSPM0G3507学习--05中断及管脚中断

关键函数&#xff1a; NVIC_EnableIRQ(IRQn_Type IRQn)&#xff1a;使能中断 例5-1&#xff1a;单按键中断方式实现led灯的亮灭 在上一讲LP-MSPM0G3507学习--04GPIO控制中实现了通过按键控制led灯的亮灭&#xff0c;可以看出程序效率不高&#xff0c;下面采用中断的方式实现…

mac系统安装、启动Jenkins,创建pytest接口自动化任务

先安装Homebrew&#xff1a;mac系统安装brew-CSDN博客 1、安装Jenkins # 可以安装长期支持版本 brew install jenkins-lts# 或者最新版本&#xff08;我安了这个&#xff09; brew install jenkins 可查看Jenkins安装位置&#xff1a; # 最新版本 brew --prefix jenkins 2、…

设置第三方窗口置顶(SetWindowPos方法,vb.net)

起源在日常办公、游戏时&#xff0c;我们经常需要一些窗口处于置顶状态&#xff0c;而这些窗口往往是网页端&#xff08;浏览器&#xff09;、办公软件&#xff08;wps、office等&#xff09;&#xff0c;这些需要置顶的窗口往往自身没有明显的置顶开关&#xff0c;因此&#x…

Docker-下载和安装

一、Linux版 1.安装docker &#xff08;1&#xff09;更新软件包索引 sudo apt update &#xff08;2&#xff09;安装必要的依赖 sudo apt install apt-transport-https ca-certificates curl software-properties-common &#xff08;3&#xff09;添加 Docker 官方 GP…

电脑DLL错误修复dll微软运行库工具修复dll缺失找不到dll等问题,dll免费修复工具

解决DLL文件缺失问题&#xff1a;我的使用体验与建议 在使用电脑的过程中&#xff0c;我们常常会遇到软件或系统报错&#xff0c;例如“无法找到指定模块”或“缺少某.dll文件”等提示。DLL&#xff08;动态链接库&#xff09;是Windows系统中不可或缺的组件&#xff0c;为应用…

HTTPS的工作原理及DNS的工作过程

HTTPSHTTP协议安全上存在以下三个风险&#xff1a;完整性 可用性 保密性窃听风险&#xff0c;比如通信链路上可以获取通信内容&#xff0c;用户号容易没。篡改风险&#xff0c;比如强制植入垃圾广告&#xff0c;视觉污染&#xff0c;用户眼容易瞎。冒充风险&#xff0c;比如冒充…

VisualXML全新升级 | 新增BusLoad计算

VisualXML是一个功能强大的网络总线设计工具&#xff0c;专注于简化汽车电子系统中复杂的网络数据设计操作。该软件支持多种主流总线网络格式的数据编辑&#xff08;如DBC、LDF、ARXML、HEX等&#xff09;&#xff0c;并能够基于Excel表格的方式生成和转换多种数据库文件。由此…

李天意考研数学精讲课学习笔记(课堂版)

视频链接&#xff1a;【考研数学精讲课李天意】基础强化真题&#xff0c;概念精讲与解题技巧&#xff08;适用数学一/二/三&#xff09;_哔哩哔哩_bilibili 讲义&#xff1a;夸克网盘分享 高数6 不定积分

闲庭信步使用图像验证平台加速FPGA的开发:第二十三课——图像直方图和灰度图像叠加的FPGA实现

&#xff08;本系列只需要modelsim即可完成数字图像的处理&#xff0c;每个工程都搭建了全自动化的仿真环境&#xff0c;只需要双击top_tb.bat文件就可以完成整个的仿真&#xff0c;大大降低了初学者的门槛&#xff01;&#xff01;&#xff01;&#xff01;如需要该系列的工程…

C++并发编程-14. 利用栅栏实现同步

前文我们通过原子操作实战实现了无锁队列&#xff0c;今天完善一下无锁的原子操作剩余的知识&#xff0c;包括Relaese和Acquire内存序在什么情况下是存在危险的&#xff0c;以及我们可以利用栅栏机制实现同步等等。 线程可见顺序 我们提到过除了memory_order_seq_cst顺序&#…

如何选择旅游科技行业云ERP?Oracle NetSuite助力汇智国际数智化升级

2025年4月21日&#xff0c;汇智国际旅游发展有限公司&#xff08;以下简称汇智国际&#xff09;携手 Oracle NetSuite与Hitpoint Cloud &#xff0c;共同参与了汇智国际 Oracle NetSuite 云ERP 项目启动会。 本次会议标志着汇智国际在数字化转型道路上迈出了坚实而关键的一步&…

深度学习零基础入门(3)-图像与神经网络

好久不见~我又回来了 这一节我们来讲一讲图像在计算机中的本质&#xff0c;以及全连接神经网络的缺陷&#xff0c;进而引出卷积神经网络一、图像在计算机中的本质 不知道你有没有学过数据结构&#xff0c;在讲这一部分的时候对数组进行了扩展&#xff0c;讲到了广义表和压缩矩阵…