- 1、本文档共12页,可阅读全部内容。
- 2、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。
- 3、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载。
- 4、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
- 5、该文档为VIP文档,如果想要下载,成为VIP会员后,下载免费。
- 6、成为VIP后,下载本文档将扣除1次下载权益。下载后,不支持退款、换文档。如有疑问请联系我们。
- 7、成为VIP后,您将拥有八大权益,权益包括:VIP文档下载权益、阅读免打扰、文档格式转换、高级专利检索、专属身份标志、高级客服、多端互通、版权登记。
- 8、VIP文档为合作方或网友上传,每下载1次, 网站将根据用户上传文档的质量评分、类型等,对文档贡献者给予高额补贴、流量扶持。如果你也想贡献VIP文档。上传文档
查看更多
--(完美WORD文档DOC格式,可在线免费浏览全文和下载)值得下载!
算法与数据结构期中复习 1.设n是偶数,试计算运行下列程序段后m的值,并给出该程序段的时间复杂度。 m=0; for (i=1;i=n;i++) for (j=2*i;j=n;j++) m=m+1; 答:时间复杂度为O(n2),m的值等于赋值语句m=m+1的运行次数,其计算式为: 下列算法对一n位二进制数加1,假如无溢出,该算法在最坏情况下时间复杂度是什么?并分析它的平均时间复杂度。 void func (int A[n]) //A[n]中每个元素取值0或1 { int i=n; while (A[i]==1) { A[i]=0; i--; } A[i]=1; } 答:算法在最好情况下,即二进制数的最后一位为零时,只作一次判断,未执行循环体,赋值语句A[i]执行了一次;最坏情况出现在二进制数各位均为1(最高位为零,因题目假设无溢出),这时判断n次,循环体执行了n-1次,时间复杂度是O(n), 平均情况:应该考虑从最低位其连续1的个数。 ***0-2(n-1) 循环体判断条件执行1次 **01 - 2(n-2)循环体判断条件执行2次 **011-2(n-3)循环体判断条件执行3次 **01..1(i个1)- 2(n-i-1)循环体判断条件执行i次 1..1(n个1)-1循环体判断条件执行n次 平均情况时间复杂度为0(n) 请在下列算法的横线上填入适当的语句。 typedef struct node {int data; struct node *next; }linknode,*link; bool inclusion(link ha,link hb) /*以ha和hb为头指针的带头节点单链表分别表示递增有序表A和B,本算法判别表A是否包含在表B内,若是,则返回“true”,否则返回“false”*/ { pa=ha-next; pb=hb-next; (1) ; while ((2) ) { if (pa-data==pb-data ) (3); else (4) ; } (5) ; } (1) if (pa==NULL) return(TRUE); (2) pb!=NULL pa-data=pb-data (3) return(inclusion(pa,pb)); (4) pb=pb-next; (5) return(FALSE); 试推导求解 n 阶hanoi塔问题至少要执行的移动操作 move 次数。 答:设Hn为n个盘子的Hanoi塔的移动次数。(假定n个盘子从钢针X移到钢针Z,可借助钢针Y) 则 Hn =2Hn-1+1 //先将n-1个盘子从X移到Y,第n个盘子移到Z,再将那n-1个移到Z =2(2Hn-2+1)+1 =22 Hn-2+2+1 =22(2Hn-3+1)+2+1 =23 Hn-3+22+2+1 · · · = 2k Hn-k+2k-1 +2k-2 +…+21 +20 =2n-1 H1+2n-2+2n-3+…+21+20 因为H1=1,所以原式Hn=2n-1+2n-2+…+21+20=2n-1 试证明:若借助栈由输入序列1,2,…,n得到输出序列为P1,P2,…,Pn(它是输入序列的一个排列),则在输出序列中不可能出现这样的情形:存在着ijk,使PjPkPi。 答:如果ij,则对于pipj情况,说明pi在pj入栈前先出栈。而对于pipj的情况,则说明要将pj压到pi之上,也就是在pj出栈之后pi才能出栈。这就说明,对于ijk,不可能出现pjpkpi的输出序列。 试证明:同一棵二叉树的所有叶子结点,在先序序列、中序序列以及后序序列中都按相同的相对位置出现(即先后顺序相同),例如先序abc,后序bca 中序bac。 前序遍历是“根左右”,中序遍历是“左根右”,后序遍历是“左右根”。三种遍历中只是访问“根”结点的时机不同,对左右子树均是按左右顺序来遍历的,因此所有叶子都按相同的相对位置出现。 访问“根”结点的时机,可参考栈的入栈和出栈! 判断二叉树是否为完全二
您可能关注的文档
- 双级蒸汽压缩式复叠式制冷循环.ppt
- 双间隙圆柱同轴封闭谐振腔等效电路与分析法论文.doc
- 双氰胺甲醛树脂(DF)改性淀粉胶粘剂合成应用(论文).doc
- 双燃料发动机结构典型故障检修.doc
- 双调风旋流燃烧器W火焰锅炉燃烧特性应用研究.doc
- 双相干谱算法在旋转机械诊断中研究毕业.doc
- 双星GNSS在静态相对定位测量精度与分析-冯国正.doc
- 水稻不育系V20A提纯复壮繁殖技术应用研究.doc
- 水流量开关工作原理水流量计.doc
- 水喷雾细水雾灭火系统.ppt
- 数据仓库:Redshift:Redshift与BI工具集成.docx
- 数据仓库:Redshift:数据仓库原理与设计.docx
- 数据仓库:Snowflake:数据仓库成本控制与Snowflake定价策略.docx
- 大数据基础:大数据概述:大数据处理框架MapReduce.docx
- 实时计算:GoogleDataflow服务架构解析.docx
- 分布式存储系统:HDFS与MapReduce集成教程.docx
- 实时计算:Azure Stream Analytics:数据流窗口与聚合操作.docx
- 实时计算:Kafka Streams:Kafka Streams架构与原理.docx
- 实时计算:Kafka Streams:Kafka Streams连接器开发与使用.docx
- 数据仓库:BigQuery:BigQuery数据分区与索引优化.docx
文档评论(0)