数据结构与算法——二分查找
2021/7/29 1:08:33
本文主要是介绍数据结构与算法——二分查找,对大家解决编程问题具有一定的参考价值,需要的程序猿们随着小编来一起学习吧!
基本介绍
代码实现
/** * 二分查找要求数组有序 * @param arr 数组 * @param left 左索引 * @param right 右索引 * @param value 查找的数据 * @return 包含数据索引的集合 */ public static ArrayList<Integer> binarySearch(int[] arr, int left, int right, int value) { //没找到 if (left > right) { return new ArrayList<Integer>(); } int mid = (left + right) / 2; if (value > arr[mid]) { //向右递归 return binarySearch(arr, mid + 1, right, value); } else if (value < arr[mid]) { //向左递归 return binarySearch(arr, left, mid - 1, value); } else { //已找到,将数据索引加入集合 ArrayList<Integer> resIndexList = new ArrayList<>(); resIndexList.add(mid); //向mid左边扫描,将所有与arr[mid]相同的数据放入集合中 int temp = mid-1; while (temp >= 0 && arr[temp] == value) { resIndexList.add(temp); temp--; } //向mid右边扫描,将所有与arr[mid]相同的数据放入集合中 temp = mid+1; while (temp <= arr.length - 1 && arr[temp] == value) { resIndexList.add(temp); temp++; } return resIndexList; } }
这篇关于数据结构与算法——二分查找的文章就介绍到这儿,希望我们推荐的文章对大家有所帮助,也希望大家多多支持为之网!
- 2025-01-10百万架构师第十三课:源码分析:Spring 源码分析:Spring核心IOC容器及依赖注入原理|JavaGuide
- 2025-01-10便捷好用的电商API工具合集
- 2025-01-09必试!帮 J 人团队解决物流错发漏发的软件神器!
- 2025-01-09不容小觑!助力 J 人物流客服安抚情绪的软件!
- 2025-01-09为什么医疗团队协作离不开智能文档工具?
- 2025-01-09惊叹:J 人团队用啥软件让物流服务快又准?
- 2025-01-09如何利用数据分析工具优化项目资源分配?4种工具推荐
- 2025-01-09多学科协作难?这款文档工具可以帮你省心省力
- 2025-01-09团队中的技术项目经理TPM:工作内容与资源优化策略
- 2025-01-09JIT生产管理法:优化流程,提升竞争力的秘诀