递归和分治

递归

        递归函数是指自己调用自己的函数,是设计算法时的一种编程技巧。

        但是注意,递归函数必须有一个终点,否则程序会一直运行下去。

分治法

        利用递归的技巧,将问题分成多个局部问题,使用递归函数求出每个局部问题的解,再将结果整合,最终解决原问题,这种编程手法称为分治法。

        1.将问题分割成多个局部问题。

        2.递归求出局部问题。

        3.将局部问题的解整合,解决原问题。  

    private static   int getMaxValue(int[] table, int left, int right){
        // 结束的条件
        if (left == right) {
            return table[left];
        }
        int middle = (left + right) / 2;
        int leftMax = getMaxValue(table, left, middle);
        int rightMax = getMaxValue(table, middle + 1, right);
        return Math.max(leftMax, rightMax);
    }

    public static void main(String[] args) {
        int[] a = {2,2,3,4,1,56,6568,5,3,54,6,6568,5};
        System.out.println("【分治】该数组中最大值为:"+getMaxValue(a,0,a.length - 1));

        int asInt = Arrays.stream(a).max().getAsInt();
        System.out.println("【Stream】该数组中最大值为:"+asInt);
        
        Arrays.sort(a);
        System.out.println("【arraySort】该数组中最大值为:"+a[a.length- 1]);

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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值