二分查找递归算法——java

本文介绍了一种使用递归实现的二分查找算法,并提供了具体的Java代码实现。通过对递归二分查找法的讲解,帮助读者更好地理解二分查找算法及其递归特性。

引言:笔者发现这段时间访问量最多的文章是二分查找法,由此可见其重要性

恰巧最近对递归算法比较感兴趣,所以就写了这篇文章,希望能到帮助大家更加深刻的理解到二分查找算法和递归算法的美妙之处

	/**
	 * 递归二分查找法
	 *
	 * @param arr	需要进行查询操作的数组
	 * @param len	数组的长度
	 * @param num	需要在数组中查询的数据
	 * @return	返回结果
	 */
	 public static Integer search(int[] arr,int lo,int hi,int num){

        // 指针重合说明数组中没有num
        if (lo <= hi){

            int index = (lo+hi)/2;

            if (arr[index] == num) {

                return index;
                
                // 当前基数大于num 基于折半后的前一位开始查询
            }else if (arr[index] > num){

                return search(arr,lo,index - 1,num);

                // 当前基数小于num 基于基数的后一位开始查询
            }else if (arr[index] < num){

                return search(arr,index + 1,hi,num);

            }

        }

        return -1;
    }

 具体实现步骤就不再一一注释了,两种算法的美妙之处请读者自行体会 ...

                  {\__/}                                          {\__/}
                  ( ·-·)                                          (·-· )
                  / >------------------------------------------------< \
                           |      ☆                            |
                           |         ☆                         |
                           |  ★                                |
                           |         ☆                         |
                           |      ☆                            |
                           |                                   |
                           -------------------------------------

 

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值