基础算法-递推算法-学习

现象:

基础算法-递推算法-学习

方法:

这就是一种递推的算法思想。递推思想的核心就是从已知条件出发,逐步推算出问题的解

最常见案例:

一:正向递推案例:

弹力球回弹问题:

* 弹力球从100米高度自由落下,

* 每次落地后反跳回原高度的一半,并再落下

* 求它在第10次落地时,共经过多少米?第10次反弹多高?

代码方法:

复制代码
    public static void forward() {
        // 总路径
        double sum = 100;
        // 每次反弹双向路径
        double h = 100;
        //第二次开始计算反弹 所以从2开始
        for (int i = 2; i <= 10; i++) {
            sum += h;
            h = h / 2;
            log.debug("当前第{}次,总路径:{}", i, sum);
        }
        log.debug("经过十次之后总路径:{}", sum);

        log.debug("=========================================");

        double he = 100;
        for (int y = 1; y <= 10; y++) {
            he /= 2;

            log.debug("当前第{}次," + "反弹高度:{}", y, he);
        }
    }

二:逆向递推案例:

小明吃饼干问题:

小明有一盒饼干

* 每天早上都吃一半,在分2块给同学

* 到第10天早上想再吃时,只剩下一块饼干了。求小明的一盒饼干有多少块?

代码方法:

复制代码
    public static void reverse() {
        int remain=1;

        for (int i=9;i>=1;i--){
            remain=(remain+2)*2;
            log.debug("当前第{}天,饼干剩余数量:{}",i,remain);
        }
    }

三:函数案例

斐波那契数列 \ 黄金分割数列

由意大利数学家列昂纳多・斐波那契(Leonardo Fibonacci)提出:

* 斐波那契数列指的是这样的一个数列:1、1、2、3、5、8、13、21、34、......,

* 这个数列从第 3 项开始,每一项都等于前面两项之和。在数学上斐波那契数列可以被递推的方法定义如下:

* F(1)=1,F(2)=1, F(n)=F(n - 1)+F(n - 2)(n ≥ 3,n ∈ N*)

代码方法:

复制代码
    public static void fibo() {
        int a=0;
        int b=1;
        int f=1;

        log.debug("当前第1列 a:{} b:{}  数值:{}", a,b,f);
        for (int i=2;i<=21;i++){
            f=a+b;
            a=b;
            b=f;
            log.debug("当前第{}列 a:{} b:{}  数值:{}", i,a,b,f);
        }
    }
相关推荐
AOwhisky11 分钟前
Kubernetes 学习笔记:集群管理、命名空间与 Pod 基础
linux·运维·笔记·学习·云原生·kubernetes
code_pgf36 分钟前
Octo 算法详解-开源通用机器人策略模型技术报告
算法·机器人·开源
嘻嘻哈哈樱桃1 小时前
牛客经典101题题解集--动态规划
java·数据结构·python·算法·职场和发展·动态规划
光影少年1 小时前
大屏页面,一次多个请求,请求加密导致 点击 全局时间选择器 时出现卡顿咋解决(面板收起会延迟1~2秒)
前端·javascript·vue.js·学习·前端框架·echarts·reactjs
脱氧核糖核酸__1 小时前
LeetCode热题100——234.回文链表(两种解法)
c++·算法·leetcode·链表
IronMurphy1 小时前
【算法四十二】118. 杨辉三角 198. 打家劫舍
算法
电科一班林耿超1 小时前
第 16 课:动态规划专题(二)—— 子序列与子数组问题:面试最高频的 DP 题型
数据结构·算法·动态规划
生信研究猿2 小时前
leetcode 416. 分割等和子集
算法·leetcode·职场和发展
sakiko_2 小时前
UIKit学习笔记2-组件嵌套、滚动视图等
笔记·学习·objective-c·swift·uikit
狗哥哥2 小时前
面包屑自动推导的算法设计:从“最短路径匹配”到工程可落地
算法·架构