二分查找

2020-07-14  本文已影响0人  YAOPRINCESS
import java.util.ArrayList;

/**
 * @author klr
 * @create 2020-07-14-12:26
 */
public class BinarySearch {


    public static void main(String[] args) {
        int[] arr = new int[]{11, 66, 22, 44,44,44,44, 99};
        System.out.println(BinarySearch.search1(arr, 0, arr.length - 1, 44).toString());
    }


    public static int search(int[] arr, int left, int right, int findVal){

        //如果找不到这个数,要给个出口
        if (left > right) {
            return -1;
        }

        int mid=(left+right)/2;
        int midVal=arr[mid];
        if(midVal>findVal){
            return search(arr, left, mid - 1, findVal);
        } else if (midVal < findVal) {
            return search(arr, mid + 1, right, findVal);
        }
        else{
            return midVal;
        }
    }

    //可查找所有的下标
    public static ArrayList<Integer> search1(int[] arr, int left, int right, int findVal){

        //如果找不到这个数,要给个出口
        if (left > right) {
            return new ArrayList<>();
        }

        int mid=(left+right)/2;
        int midVal=arr[mid];
        if(midVal>findVal){
            return search1(arr, left, mid - 1, findVal);
        } else if (midVal < findVal) {
            return search1(arr, mid + 1, right, findVal);
        }
        else{

            ArrayList<Integer> integers = new ArrayList<>();
            int temp=mid-1;
            while (temp >= 0 && arr[temp] == midVal) {
                integers.add(temp);
                temp--;
            }
            integers.add(mid);
            temp=mid+1;
            while (temp <= arr.length - 1 && arr[temp] == midVal) {
                integers.add(temp);
                temp++;
            }
            return integers;
        }
    }
}

上一篇 下一篇

猜你喜欢

热点阅读