第1讲 递推与迭代.pptVIP

  1. 1、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。。
  2. 2、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载
  3. 3、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
  4. 4、该文档为VIP文档,如果想要下载,成为VIP会员后,下载免费。
  5. 5、成为VIP后,下载本文档将扣除1次下载权益。下载后,不支持退款、换文档。如有疑问请联系我们
  6. 6、成为VIP后,您将拥有八大权益,权益包括:VIP文档下载权益、阅读免打扰、文档格式转换、高级专利检索、专属身份标志、高级客服、多端互通、版权登记。
  7. 7、VIP文档为合作方或网友上传,每下载1次, 网站将根据用户上传文档的质量评分、类型等,对文档贡献者给予高额补贴、流量扶持。如果你也想贡献VIP文档。上传文档
查看更多

常用算法与程序设计常用算法与程序设计第1讲递推与迭代VisualFoxPro*第1页,共27页,星期日,2025年,2月5日常用算法与程序设计*主要内容递推概述递推数列应用递推求解应用题递推与递归比较迭代及其应用第2页,共27页,星期日,2025年,2月5日常用算法与程序设计*1.1递推概述1.1.1递推算法递推是一种高效的数学模型,是组合数学中的一个重要解题方法。递推是利用问题本身所具有的一种递推关系求解问题的一种方法。递推算法的首要问题是得到相邻的数据项之间的关系,即递推关系。第3页,共27页,星期日,2025年,2月5日常用算法与程序设计*1.实施递推的步骤(1)确定递推变量(2)建立递推关系(3)确定初始(边界)条件(4)对递推过程进行控制1.1.2递推实施步骤与描述第4页,共27页,星期日,2025年,2月5日常用算法与程序设计*2.递推算法框架描述(1)简单顺推算法顺推即从前往后推,从已求得的规模为1,2,…,i-1的一系列解,推出问题规模为i的解,直至得到规模为n的解。简单顺推算法框架描述:f(1—i-1)=初始值;/*确定初始值*/for(k=i;k=n;k++)f(k)=递推关系式;/*施递推*/printf(f(n));/*输出n规模的解f(n)*/第5页,共27页,星期日,2025年,2月5日常用算法与程序设计*(2)简单逆推算法逆推即从后往前推,从已得的规模为n,n-1,…,i+1的一系列解,推出问题规模为i的解,直至得到规模为1的解。简单逆推算法框架描述:f(n—i+1)=初始值;/*确定初始值*/for(k=i;k=1;k--)f(k)=递推关系式;/*实施递推*/printf(f(1));/*输出解f(1)*/第6页,共27页,星期日,2025年,2月5日常用算法与程序设计*设递推的二维数组为f(k,j),1≤k≤n,1≤j≤m。二维数组顺推算法框架描述:f(1,1—m)=初始值;/*赋初始值*/for(k=2;k=n;k++)for(j=1;j=m;j++)f(k,j)=递推关系式;/*实施递推*/printf(f(n,m));/*输出解f(n,m)*/(3)二维数组顺推算法第7页,共27页,星期日,2025年,2月5日常用算法与程序设计*当递推关系包含两个或两个以上关系式时,通常应用多关系分级递推算法求解。(4)多关系分级递推算法f(1—i-1)=初始值;/*赋初始值*/for(k=i;k=n;k++)if(条件1)f(k)=递推关系式1;/*据递推关系1递推*/if(条件2)f(k)=递推关系式2;/*据递推关系2递推*/……if(条件m)f(k)=递推关系式m;/*据递推关系m递推*/printf(f(n));/*输出解f(n)*/第8页,共27页,星期日,2025年,2月5日常用算法与程序设计*1.2递推数列(1)递推算法设计设置k循环(k=1,2,…,n,其中n为输入整数),在k循环外赋初值:a=2;b=3;s=0;在k循环中比较赋值:当ab时,由赋值f[k]=a确定为序列的第k项;然后a=a*2,即a按递推规律乘2,为后一轮比较作准备;当ab时,由赋值f[k]=b确定为序列的第k项;然后b=b*3,即b按递推规律乘3,为后一轮比较作准备。1.2.1幂序列第9页,共27页,星期日,2025年,2月5日常用算法与程序设计*递推过程描述:a=2;b=3;*为递推变量a,b赋初值*/for(k=1;k=n;k++){if(ab){f[k]=a;a=a*2;}/*用a给f[k]赋值*/else{f[k]=b;b=b*3;}/*用b给f[k]赋值*/}在这一算法中,变量a,b是变化的,分别代表2的幂与3的幂。第10页,共27页,星期日,2025年,2月5日常用算法与程序设计*1.2.2双关系递推数列(1)算法设计要点设n个数在数组m中,2x+1与3x+1均

文档评论(0)

xiaoyao2022 + 关注
实名认证
文档贡献者

该用户很懒,什么也没介绍

1亿VIP精品文档

相关文档