Java数据结构-二分查找

1、通过两边的指针,和中间值的比较决定向那一边进行递归比较

2、需要注意的点是,进行比较端点值时,需要单独考虑left和right指针重合的情况,否者将会导致查找两端值出现无法查找的情况



/*
二分查找
 */
import java.util.ArrayList;
import java.util.Arrays;

public class BinarySearchDemo {
    public static void main(String[] args){
        int[] arr = {1,8,10,89,89,1000,1234};
//        System.out.println(binarySearch(arr,0,arr.length-1,1234));
        for (int elem2:arr
             ) {
            ArrayList<Integer> arrayList = binarySearch2(arr,0,arr.length-1,elem2);
            if(arrayList.size()!=0){
                for (Integer elem: arrayList
                ) {
                    System.out.println(elem);
                }
            }else{
                System.out.println("无法查找到有效值!");
            }
            System.out.println("********************************* ");

        }
        /*
        ArrayList<Integer> arrayList = binarySearch2(arr,0,arr.length-1,1234);
        if(arrayList.size()!=0){
            for (Integer elem: arrayList
                 ) {
                System.out.println(elem);
            }
        }else{
            System.out.println("无法查找到有效值!");
        }
        System.out.println();

         */

    }
    // 二分查找的方法
    public static int binarySearch(int[] arr,int left,int right,int findVal){
        System.out.println("查找次数");
        // 二分查找的方法
        int mid = (left+right)/2;
        int midVal = arr[mid];


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

    }

    // 返回多个相同值的改进方法
    public static ArrayList binarySearch2(int[] arr, int left, int right, int findVal){

        // 二分查找的方法
        int mid = (left+right)/2;
        int midVal = arr[mid];


        if(left==right){
            if(midVal == findVal){
                ArrayList arrayList = new ArrayList();
                arrayList.add(mid);
                return arrayList;
            }
        }
        if(left<right){
            if(findVal > midVal){
                // 向右递归
                return binarySearch2(arr,mid+1,right,findVal);
            }else if(findVal < midVal){
                return binarySearch2(arr,left,mid-1,findVal);
            }else{
                ArrayList<Integer> arrayList = new ArrayList<>();
                int temp = mid-1;
                while(true){
                    if(temp <0||arr[temp]!=findVal){
                        break;
                    }
                    // 将temp放入到arrayList
                    arrayList.add(temp--); // temp向左边移动

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

                }
                return arrayList;
            }
        }
        ArrayList arrayList = new ArrayList<>();
        return arrayList;

    }

}

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值