欢迎您访问程序员文章站本站旨在为大家提供分享程序员计算机编程知识!
您现在的位置是: 首页

二分查找算法的思路及代码实现

程序员文章站 2024-03-20 09:50:10
...
package Search;

import java.util.ArrayList;
import java.util.List;

/*
1.二分查找:
1.1首先确定该数组的中间下标-->mid = (left + right) / 2;初始化left = 0,right = arr.length - 1
1.2 然后让需要查找的数findValue 和 arr[mid] 比较
1.3 如果 findValue > arr[mid],说明要找的数在mid 的右边,因此需要递归向右查找
1.4 如果 findValue < arr[mid],说明要找的数在mid 的左边,因此需要递归向左查找
1.5 如果findValue == arr[mid],说明找到,就返回

递归退出的条件:
1)找到就结束递归findValue == arr[mid]
2)递归完整个数组,仍然没有找到findValue,也需要结束递归,条件是当left > right 的时候

 */
public class BinarySearch {
    public static void main(String[] args) {
        int [] arr = {1,2,4,8,8,8,23,30};
        List<Integer> list = binarySearch02(arr,8,0, arr.length - 1);
        if(list.size() != 0){
            System.out.println(list);
        } else{
            System.out.println("没有找到--");
        }
    }
    //要查找的数组必须是 有序 的
    public static int binarySearch(int [] arr, int findVal,int left, int right){
        //当left > right 时,说明没有找到
        if(left > right){
            return -1;
        }
        int mid = (left + right) / 2;
        int midVal = arr[mid];

        if(findVal > midVal){
            //向右递归
            return binarySearch(arr,findVal,mid + 1, right);
        } else if (findVal < midVal){
            return binarySearch(arr,findVal,left,mid - 1);
        }else{
            return mid;
        }
    }

    //如果要找到 数组中等于findVal的 所有值
    //思路:找到mid值时,不要马上返回
    //向mid索引值的左边扫描,将所有==findVal的所有值的下标加入ArrayList中
    //向mid索引值的右边扫描,将所有==findVal的所有值的下标加入ArrayList中
    //要查找的数组必须是 有序 的
    public static List<Integer> binarySearch02(int [] arr, int findVal,int left, int right){
        //当left > right 时,说明没有找到,返回一个空的集合
        if(left > right){
            return new ArrayList<Integer>();
        }

        int mid = (left + right) / 2;
        int midVal = arr[mid];

        if(findVal > midVal){
            //向右递归
            return binarySearch02(arr,findVal,mid + 1, right);
        } else if (findVal < midVal){
            return binarySearch02(arr,findVal,left,mid - 1);
        }else{
            List<Integer> list = new ArrayList<>();
            int temp = mid - 1;
            while (true){
                if(temp < 0 || arr[temp] != findVal){
                    break;
                }

                list.add(temp);
                temp -= 1;
            }
            list.add(mid);

            temp = mid + 1;
            while (true){
                if (temp > arr.length - 1 || arr[temp] != findVal){
                    break;
                }
                list.add(temp);
                temp += 1;
            }

            return list;
        }
    }

}

相关标签: 数据结构 java