递归理解

问题

递归要保存调用点的信息,有调用开销,算法效率低,但是胜在书写简单

解决

递归是什么?

程序自身调用自身称为递归( recursion)。
递归有直接递归和间接递归
•直接递归:函数在执行过程中调用本身。
•间接递归:函数在执行过程中调用其它函数再经过这些函数调用本身。

递归有四个特性

1.必须有可最终达到的终止条件,否则程序将陷入无穷循环;
2.子问题在规模上比原问题小,或更接近终止条件;
3.子问题可通过再次递归调用求解或因满足终止条件而直接求解;
4.子问题的解应能组合为整个问题的解。
看着很绕口,
举个栗子
等份分开10g黄金,要求每份低于1g

常用的思路是,二分法,一直分下去,直到每份低于1g
第1切割,重量为5.0
第2切割,重量为2.5
第3切割,重量为1.25
第4切割,重量为0.625
最终适宜的重量为:0.625 切割次数为:4

可以发现
1,特性:到0.65g因为满足每份低于1g而终止
2,特性:每份质量降低了,问题规模变小了
3, 特性:每次都是二分法
4. 特性:最终的每份都是解

public class RecursionTest {
    public void recursion(float weights, int times) {
        if (weights <= 1) {
            System.out.println("最终适宜的重量为:"+weights+" 切割次数为:"+times);
        }
        else{
            weights=weights / 2;
            times++;
            System.out.println("第"+times+"切割,"+"重量为"+weights);
            recursion(weights,times);
        }
    }

    public static void main(String[] args) {
        RecursionTest recursionTest = new RecursionTest();
        recursionTest.recursion(10,0);
    }
}
  • 1
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 1
    评论
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值