数据结构与算法——二分查找
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; } }
这篇关于数据结构与算法——二分查找的文章就介绍到这儿,希望我们推荐的文章对大家有所帮助,也希望大家多多支持为之网!
- 2024-11-20RabbitMQ教程:新手入门指南
- 2024-11-20Redis教程:新手入门指南
- 2024-11-20SaToken教程:新手入门指南
- 2024-11-20SpringBoot教程:从入门到实践
- 2024-11-20Java全栈教程:从入门到实战
- 2024-11-20Java微服务系统教程:入门与实践指南
- 2024-11-20Less教程:初学者快速上手指南
- 2024-11-20MyBatis教程:新手快速入门指南
- 2024-11-20QLExpress教程:初学者快速入门指南
- 2024-11-20订单系统教程:从入门到实践的全面指南