算法分析与设计——递归算法(一)

简介: 算法分析与设计——递归算法(一)

1. 递归含义与特征

递归含义:一种自身调用自身或间接调用自身的算法.核心将大规模问题转化为小规模问题,小规模问题是大规模问题的解。
递归问题特征:1.问题P涉及数据规模P(size)
            2.问题规模发生变化后,解决问题的方法完全相同,并且原问题(通常是大规模问题)的解释由小规模问题的解构成
          3.小规模问题是可以求解的(在有限步内可以停机) 解决递归问题的思想核心是归纳法,归纳法思想核心:
                         1.基础步:a1是问题P(1)的解
                          2.归纳步:归纳出某种通用的式子可以满足任意值 得出通式  即an=P(n)的解

2. 例题

1.基于递归算法的插入排序
 对n个元素组成的数组A进行排序
 输入:数组A[],数组中的元素个数n
 输出:按非递减顺序排序的数组A【】
 思路:
     插入排序是在已知有序的数组中插入一个元素通过组内比较大小找到一个合适的位置,将找到的位置之后的元素整体后移再插入元素,使之成为新的有序数组,然后依次扩大有序的数组,进行相同的操作,直到数组取完。
     找出特征:1.首先找出数据规模:SIZE=n;
             2.找出对规模改变后的相同的解决方法:组内比较找到位置,位置之后的元素整体后移
             3.小规模问题有解:n=1 有序
     归纳:
     基本步:
             当n=1时 数组只有一个A[0],不需要排序比较。
     归纳步:  
             通过组内比较大小找到一个合适的位置,将找到的位置之后的元素整体后移再插入元素。
 代码实现:
 void insert_sort_rec(Type A[],int n){
     Type a;
     n=n-1;
     if(n>0)//小规模问题有解
     {
     insert_sort_rec(A[n],n);//调用自身 将大规模交给小规模求解
     a=A[n];
     k=n-1;
         while((k>=0)&&(A[k]>a)){//组内比较 找到位置 整体后移
             a[k+1]=a[k];
             k=k-1;
         }
         A[k+1]=a;//此时的A[k]<a 即k+1位置是给a的 插入新元素到合适的位置
     }
 }
 算法分析:
   此算法的最坏情况时间复杂度:
   f(n)=f(n-1)+n-1=f(n-2)+(n-2)+(n-1)=f(0)+(k=1到n-1的k的累加)=n*(n-1)/2
   即时间复杂度O(n*n);
 2.多项式求值的递归算法
 设有如下的n阶多项式:Pn(x)=an*X^n+an-1*X^n-1+...+a1*x+a0
 输入:存放于数组的多项式系数A【】及x,多项式的阶数n
 输出:阶数为n的多项式的值
 思想:将上式改为秦九韶算法
      Pn=((...((((an)*x+an-1)*x+an-2)*x+an-3)*x+...)*x+a1)*x+a0
      进行归纳:
      基础步:n=0,P0=a0;
      归纳步:Pk=x*Pk-1+An-k
 代码实现:
     float qinjiushao_alm(float x,float A[],int n){
      float p;
      if(n==0){
        p=A[0];
      }else{
        p=qinjiushao_alm(x,A,n-1)*x+A[n];
      }return p;
     }
算法分析:
    f(0)=0
    f(n)=f(n-1)+1
    f(n)=O(n);
相关文章
|
1月前
|
机器学习/深度学习 人工智能 监控
AI算法分析,智慧城管AI智能识别系统源码
AI视频分析技术应用于智慧城管系统,通过监控摄像头实时识别违法行为,如违规摆摊、垃圾、违章停车等,实现非现场执法和预警。算法平台检测街面秩序(出店、游商、机动车、占道)和市容环境(垃圾、晾晒、垃圾桶、路面不洁、漂浮物、乱堆物料),助力及时处理问题,提升城市管理效率。
AI算法分析,智慧城管AI智能识别系统源码
|
1月前
|
算法
经典控制算法——PID算法原理分析及优化
这篇文章介绍了PID控制算法,这是一种广泛应用的控制策略,具有简单、鲁棒性强的特点。PID通过比例、积分和微分三个部分调整控制量,以减少系统误差。文章提到了在大学智能汽车竞赛中的应用,并详细解释了PID的基本原理和数学表达式。接着,讨论了数字PID的实现,包括位置式、增量式和步进式,以及它们各自的优缺点。最后,文章介绍了PID的优化方法,如积分饱和处理和微分项优化,以及串级PID在电机控制中的应用。整个内容旨在帮助读者理解PID控制的原理和实际运用。
93 1
|
1月前
|
算法 机器学习/深度学习 索引
【算法设计与分析】——搜索算法
【算法设计与分析】——搜索算法
40 1
|
1月前
|
算法 调度
【算法设计与分析】— —基础概念题(one)可作为日常联系或期末复习
【算法设计与分析】— —基础概念题(one)可作为日常联系或期末复习
47 1
|
1月前
|
算法 C语言 C++
嵌入式PID算法理论+实践分析
嵌入式PID算法理论+实践分析
26 0
|
1月前
|
算法
关联规则分析(Apriori算法2
关联规则分析(Apriori算法2
35 0
|
2天前
|
机器学习/深度学习 数据采集 算法
共享单车需求量数据用CART决策树、随机森林以及XGBOOST算法登记分类及影响因素分析
共享单车需求量数据用CART决策树、随机森林以及XGBOOST算法登记分类及影响因素分析
|
3天前
|
移动开发 算法 数据可视化
数据分享|Spss Modeler关联规则Apriori模型、Carma算法分析超市顾客购买商品数据挖掘实例
数据分享|Spss Modeler关联规则Apriori模型、Carma算法分析超市顾客购买商品数据挖掘实例
|
5天前
|
算法 数据可视化 大数据
圆堆图circle packing算法可视化分析电商平台网红零食销量采集数据
圆堆图circle packing算法可视化分析电商平台网红零食销量采集数据
33 13
|
11天前
|
算法 数据可视化 Python
Python中LARS和Lasso回归之最小角算法Lars分析波士顿住房数据实例
Python中LARS和Lasso回归之最小角算法Lars分析波士顿住房数据实例
17 0