算法实验经典两道题.doc

  1. 1、本文档共2页,可阅读全部内容。
  2. 2、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。
  3. 3、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载
  4. 4、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
查看更多
实验一:递归函数的设计与实现 实验目的:掌握递归函数的设计与实现方法 实验原理: 递归函数的设计 实验步骤:编写程序实现教材P12例2-5 整数划分问题 问题描述:整数划分问题是将一个正整数n拆成一组数连加并等于n的形式,且这组数中的最大加数不大于n。 思路:递归函数的声明为 int split(int n, int m);其中n为要划分的正整数,m是划分中的最大加数(当m n时,最大加数为n), ??? 1 当n = 1或m = 1时,split的值为1,可根据上例看出,只有一个划分1 或 1 + 1 + 1 + 1 + 1 + 1 ??? 可用程序表示为if(n == 1 || m == 1) return 1; ??? 2 下面看一看m 和 n的关系。它们有三种关系 ??? (1) m n ??? 在整数划分中实际上最大加数不能大于n,因此在这种情况可以等价为split(n, n); ??? 可用程序表示为if(m n) return split(n, n);??? ??? (2) m = n ??? 这种情况可用递归表示为split(n, m - 1) + 1,从以上例子中可以看出,就是最大加 ??? 数为6和小于6的划分之和 ??? 用程序表示为if(m == n) return (split(n, m - 1) + 1); ??? (3) m n ??? 这是最一般的情况,在划分的大多数时都是这种情况。 ??? 从上例可以看出,设m = 4,那split(6, 4)的值是最大加数小于4划分数和整数2的划分数的和。 ??? 因此,split(n, m)可表示为split(n, m - 1) + split(n - m, m) ??? 实验要求:(1)使用C++或TC2.0 (2)上机前要有源代码或流程图。 实验二:归并排序的分治策略设计 实验目的:掌握使用分治策略消除递归;基本掌握分治策略的原理方法。 实验原理: 分治策略 实验步骤:利用分治策略编程实现合并排序,教材P21-22; 问题描述:合并排序(MERGE SORT),是用分之策略实现对n个元素进行排序的算法。合并的含义就是将两个或两个以上的有序数据序列合并成一个新的有序数据序列,因此它又叫归并算法。 算法思想:基本思想是将待排序元素分成大小大致相同的两个子集合,分别对两个子集合进行排序,最终将排好序的子集合合并成为所要求的排好序的集合。 方案一:假设数组A有N个元素,那么可以看成数组A是又N个有序的子序列组成,每个子序列的长度为1,然后再两两合并,得到了一个N/2个长度为2或1的有序子序列,再两两合并,如此重复,值得得到一个长度为N的有序数据序列为止,这种排序方法称为2—路合并排序。 方案二:给定n个元素(也叫关键字)序列a[1], ..., a[n],将其划分为两个集合a[1], ..., a[n/2]和a[n/2+1], ..., a[n]。每个集合各自进行排序,归并所得的有序序列可以得到一个新的有n个元素的有序序列。在其中,分解操作是得到两个相同大小的集合,而归并操作将两个有序集合合二为一。 实验要求:(1)使用C++或TC2.0 (2)上机前要有源代码或流程图。

文档评论(0)

ktj823 + 关注
实名认证
内容提供者

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

1亿VIP精品文档

相关文档