- 1、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。。
- 2、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载。
- 3、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
- 4、该文档为VIP文档,如果想要下载,成为VIP会员后,下载免费。
- 5、成为VIP后,下载本文档将扣除1次下载权益。下载后,不支持退款、换文档。如有疑问请联系我们。
- 6、成为VIP后,您将拥有八大权益,权益包括:VIP文档下载权益、阅读免打扰、文档格式转换、高级专利检索、专属身份标志、高级客服、多端互通、版权登记。
- 7、VIP文档为合作方或网友上传,每下载1次, 网站将根据用户上传文档的质量评分、类型等,对文档贡献者给予高额补贴、流量扶持。如果你也想贡献VIP文档。上传文档
查看更多
迭代算法.ppt
迭代算法 也称“辗转法”,是一种不断用变量的旧值递推出新值的解决问题的方法。一般用于数字计算,累加、累乘等都是其应用。 设计工作分为3步 (1)确定迭代模型 (2)建立迭代关系式 (3)对迭代过程进行控制 1.递推法 一般来说,一种简单的递推方式,是从小规模的问题推解出大规模问题的一种方法,也称其为“正推”。如累加过程就是在求出前n-1项和的基础上推出前n项和的,递推公式是Sn=Sn-1 + An 例1 求两个数的最大公约数 辗转相除法 2.倒推法 倒推法是对某些特殊问题采用的从后向前的推解问题的方法。 例2 猴子偷桃问题 一只小猴子摘了若干桃子,每天吃现有桃的一半多一个,到第10天时就只有一个桃子了,求原来有多少个桃子? 分析:每天桃子数 a10=1,a9=(1+a10)*2,a8=(1+a9)*2,… 递推公式: ai=(1+ai+1)*2 i=9,8,7,… 由于每天的桃子数只依赖于前一天的桃子数,所以用一个迭代变量代表桃子个数就可以了。 算法: main() { int i,a; a=1; for(i=9;i=1;i=i-1) a=(a+1)*2; print(a); } 蛮力法 1 枚举法 main( ){? int x,y,z;????for(x=1;x=20;x=x+1)?????????????? ????????for(y=1;y=33;y=y+1)?????????? ????????{?z=100-x-y;???????????? ???????? ?if(z mod 3=0 and 5*x+3*y+z/3=100)??????????????????????????????????????????????? {print(the cock number is,x); print(the hen number is, y); print(the chick number is ,z);}???????? }} 算法分析:以上算法只需枚举尝试20*33=660次。实现时约束条件限定Z能被3整除时,才判断“5*x+3*y+z/3=100”。这样省去了z不整除3时的算术运算和条件判断,进一步提高了算法效率。 【例2】解数字迷 A B C A B × A D D D D D D 算法设计1:按乘法枚举 1)枚举范围为: A:3——9,B:0——9,C:0——9 六位数表示:A*10000+B*1000+C*100+A*10+B,尝试800次。 2)约束条件为: 每次尝试,先求六位数与A的积,再测试积的各位是否相 同,若相同则找到了问题的解。 测试积的各位是否相同比较简单的方法是,从低位开始,每次都取数据的个位,然后整除10,使高位的数字不断变成个位,并逐一比较。 算法1如下: main( ) { int A,B,C,D,E,E1,F,G1,G2,i; for(A=3; A=9; A++) for(B=0; B=9; B++) for(C=0; C=9; C++) { F=A*10000+B*1000+C*100+A*10+B; E=F*A; E1=E; G1=E1 mod 10; for(i=1; i=5; i++) { G2=G1; E1=E1/10; G1= E1 mod 10; if(G1G2 ) break; } if(i=6) print( F,”*”,A,”=”,E); } } 2 其它范例 2 在某些情况下,需要处理很大的整数,它无法在计算机硬件能直接允许的范围内进行表示和处理。若用浮点数来存储它,只能近似地参与计算,计算结果的有效数字会受到限制。若要精确地表示大整数,并在计算结果中要求精确地得到所有位数上的数字,就必须用软件的方法来实现大整数的算术运算。请设计一个有效的算法,可以进行两个n位大整数的乘法运算。 数据结构设计:首先用数组存储大整数数据,再将两个乘数和积都按由低位到高位逐位存储到数组元素中。 算法设计:存储好两个高精度数据后,模拟竖式乘法,让两个高精度数据按位交叉相乘,并逐
您可能关注的文档
最近下载
- 631 普通生物学2018年南京师范大学考研专业课试题.pdf VIP
- 危险化学品企业“5.9相关方”解读与应用指南(雷泽佳编制-2025A1).pdf VIP
- 半导体器件物理-全套PPT课件..pptx VIP
- 劳保用品发放台账.doc VIP
- 绿城项目运营手册设计弦之景观设计分弦(2019颁布最新版).pdf VIP
- 起重机械安装维修质量保证手册-符合TSG 07-2019特种设备质量保证管理体系.pdf VIP
- 2025-《基金法律法规、职业道德与业务规范》高频考点班.pdf VIP
- 第四节化机浆.ppt
- 大学生职业生涯规划.pdf VIP
- 工会干部队伍建设调查研究报告【精选】.doc VIP
原创力文档


文档评论(0)