- 1、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。。
- 2、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载。
- 3、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
- 4、该文档为VIP文档,如果想要下载,成为VIP会员后,下载免费。
- 5、成为VIP后,下载本文档将扣除1次下载权益。下载后,不支持退款、换文档。如有疑问请联系我们。
- 6、成为VIP后,您将拥有八大权益,权益包括:VIP文档下载权益、阅读免打扰、文档格式转换、高级专利检索、专属身份标志、高级客服、多端互通、版权登记。
- 7、VIP文档为合作方或网友上传,每下载1次, 网站将根据用户上传文档的质量评分、类型等,对文档贡献者给予高额补贴、流量扶持。如果你也想贡献VIP文档。上传文档
查看更多
— PAGE \* Arabic 1 —
《计算机算法设计与分析》课程设计
《计算机算法设计与分析》课程设计 用分治法解决快速排序问题及用动态规划法解决最优二叉搜索树问题及用回溯法解决图的着色问题 一、课程设计目的: 《计算机算法设计与分析》这门课程是一门实践性非常强的课程,要求我们能够将所学的算法应用到实际中,灵活解决实际问题。通过这次课程设计,能够培养我们独立思考、综合分析与动手的能力,并能加深对课堂所学理论和概念的理解,可以训练我们算法设计的思维和培养算法的分析能力。 二、课程设计内容: 1、分治法: (2)快速排序; 2、动态规划: (4)最优二叉搜索树; 3、回溯法: (2)图的着色。 三、概要设计: 分治法—快速排序: 分治法的基本思想是将一个规模为n的 问题分解为k个规模较小的子问题,这些子问题互相独立且与原问题相同。递归地解这些子问题,然后将各个子问题的解合并得到原问题的解。分治法的条件: (1) 该问题的规模缩小到一定的程度就可以容易地解决; (2) 该问题可以分解为若干个规模较小的相同问题,即该问题具有最优子结构性质;(3) 利用该问题分解出的子问题的解可以合并为该问题的解; (4) 该问题所分解出的各个子问题是相互独立的,即子问题之间不包含公共的子子问题。 抽象的讲,分治法有两个重要步骤:(1)将问题拆开; (2)将答案合并; 动态规划—最优二叉搜索树: 动态规划的基本思想是将问题分解为若干个小问题,解子问题,然后从子问题得到原问题的解。设计动态规划法的步骤: (1)找出最优解的性质,并刻画其结构特征; (2)递归地定义最优值(写出动态规划方 程); (3)以自底向上的方式计算出最优值; (4)根据计算最优值时得到的信息,构造一个最优解。 ●回溯法—图的着色 回溯法的基本思想是确定了解空间的组织结构后,回溯法就是从开始节点(根结点)出发,以深度优先的方式搜索整个解空间。 这个开始节点就成为一个活结点,同时也成为当前的扩展结点。在当前的扩展结点处,搜索向纵深方向移至一个新结点。这个新结点就成为一个新的或节点,并成为当前扩展结点。如果在当前的扩展结点处不能再向纵深方向移动,则当前的扩展结点就成为死结点。换句话说,这个节点,这个结点不再是一个活结点。此时,应往回(回溯)移动至最近一个活结点处,并使这个活结点成为当前的扩展结点。回溯法即以这种工作方式递归的在解空间中搜索,直到找到所要求的解或解空间中以无活结点为止。 四、详细设计与实现: ●分治法—快速排序 快速排序是基于分治策略的另一个排序算 法。其基本思想是,对于输入的子数组[]r p a :,按以下三个步骤进行排序: (1)、分解(divide) 以元素[]p a 为基准元素 将[]r p a :划分为三段[]1:-q p a ,[]q a 和,[]r q a :1+使得[]1:-q p a 中任何一个元素都小于[]q a ,而[]r q a :1+中任何一个元素大于等于[]q a ,下标q 在划分过程中确定。 (2)、递归求解(conquer) 通过递归调 用快速排序算法分别对[]1:-q p a 和[]r q a :1+进行排序。 (3)、合并(merge) 由于[]1:-q p a 和[] r q a :1+的排序都是在原位置进行的,所以不必进行任何合并操作就已经排好序了。 算法实现题: 现将数列{23 21 34 45 65 76 86 46 30 39 89 20 2 3 8 47 38 54 59 40}进行快速排序。 源程序如下: #include using namespace std; #define size 20 int partition(int data[],int p,int r)
您可能关注的文档
最近下载
- 泰山版小学三年级(上册)信息技术学历案.pdf VIP
- 2025年通信公司基站铁塔建设项目技术指导手册 基站类铁塔类项目技术规范标准化.pdf VIP
- FastReport46程序员手册.doc VIP
- 凯度-2019年社交媒体趋势英文-2019 1.pdf VIP
- 班组早会培训课件.pptx VIP
- 班组早会培训课件.pptx VIP
- 幼儿教师口语 第2版 课件 19项目六任务2态势语训练.ppt
- 《空乘旅游英语视听说》课件——Check-in and Security Check.pdf VIP
- (高清版)ZT 0227-2010 地质岩心钻探规程.pdf VIP
- 医师培训考核合格证明_sample.pdf VIP
原创力文档


文档评论(0)