二分查找
二分查找也称折半查找(Binary Search),它是一种效率较高的查找方法,可以在数据规模的对数时间复杂度内完成查找。
二分查找可以应用于数组,是因为数组具有有随机访问的特点,并且 数组是有序的。
二分查找体现的数学思想是「减而治之」,可以通过当前看到的中间元素的特点推测它两侧元素的性质,以达到缩减问题规模的效果。
模板代码1. 左闭右闭的区间
public int binarySearch(int[] arr, int target) { int n = arr.length; int left = 0; int right = n - 1; // 定义 左闭右闭 区间 while (left <= right) { int middle = left + ((right - left) / 2); // 防止溢出 if (arr[middle] < target) { // target 在左区间,所以继续寻找[left, middle - 1] right = middle - 1; } else if(arr[middle] > target) { // target 在右区间,所以继续寻找[middle + 1, right] left = middle + 1; } else { // target == arr[middle],找到对应位置 return middle; } } // 没有找到对应target,此时需要注意由于 while (left <= right) 循环成立,所以最终会有 left = right + 1 || right = left + 1 return -1; }
模板代码2. 左闭右开的区间
public int binarySearch(int[] arr, int target) { int n = arr.length; int left = 0; int right = n; // 定义 左闭右闭 区间 while (left < right) { int middle = left + ((right - left) / 2); // 防止溢出 if (arr[middle] > target) { // target 在左区间,所以继续寻找[left, middle) right = middle; } else if(arr[middle] < target) { // target 在右区间,所以继续寻找[middle + 1, right) left = middle + 1; } else { // target == arr[middle],找到对应位置 return middle; } } // 没有找到对应target,此时需要注意由于 while (left < right) ,所以此时有 left = right return -1; }
没有找到对应target时,需要注意循环最后一次判断并进行分析。
【推荐】国内首个AI IDE,深度理解中文开发场景,立即下载体验Trae
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· 阿里最新开源QwQ-32B,效果媲美deepseek-r1满血版,部署成本又又又降低了!
· SQL Server 2025 AI相关能力初探
· AI编程工具终极对决:字节Trae VS Cursor,谁才是开发者新宠?
· 开源Multi-agent AI智能体框架aevatar.ai,欢迎大家贡献代码
· Manus重磅发布:全球首款通用AI代理技术深度解析与实战指南