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

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;
        }
    }

}

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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值