算法设计方法详解:贪婪算法、分而治之与动态规划

需积分: 9 13 下载量 65 浏览量 更新于2024-08-01 收藏 1.91MB PPT 举报
"贪婪算法 详细课件讲解 清华大学计算机系 数据结构与算法课件" 贪婪算法是一种在每一步选择中都采取在当前状态下最好或最优(即最有利)的选择,从而希望导致结果是全局最好或最优的算法。它的核心思想是局部最优决策,即在每个阶段都做出看似最佳的选择,期望这些局部最优的选择能导致全局最优解。在实际应用中,贪婪算法常用于解决优化问题,如Huffman编码和Dijkstra最短路径算法。 13.1 示例问题提出 贪婪算法通常通过解决一系列简单问题来处理复杂问题。例如,在Huffman编码中,算法通过每次选择具有最小权重的叶子节点来构建最优二叉树,以此实现数据的高效压缩。在Dijkstra算法中,算法每次选择当前未访问节点中距离源节点最近的一个,逐步构造出最短路径树。 13.2 贪婪算法的思想 贪婪算法的关键在于贪心选择性质,即在每一步选择中都采取最优决策。然而,这种策略并不总是能保证找到全局最优解,因为它可能因过于关注眼前的最佳选择而忽视了长远的影响。例如,当寻找有向图的最小生成树时,Prim算法或Kruskal算法采用贪婪策略,但它们必须在没有全局信息的情况下做出决策,可能会错过全局最优解。 14. 分而治之算法 分而治之是一种将大问题分解为小问题,然后分别解决这些小问题,最后合并其结果来解决原问题的方法。典型的例子包括折半查找、快速排序和归并排序。该算法的特点是自顶向下,问题分解成不重复的子问题,并通过“分”、“治”、“合”三步来解决问题。 15. 动态规划 动态规划是一种通过解决子问题来构建最优解的算法。它通过存储子问题的解,避免重复计算,以空间换取时间。例如,Floyd算法通过填充距离矩阵逐步找出所有源点到其他点的最短路径。动态规划依赖于最优子结构和重叠子问题,保证能找到全局最优解。 16. 回溯算法 回溯算法类似于动态规划,也是一种在解空间树中搜索的过程。但它允许回退到先前的状态,跳过无解的分支,以寻找满足条件的解。如迷宫问题和八皇后问题,回溯算法能有效地避免无效的搜索。 17. 分枝定界算法 分枝定界算法在搜索解空间树时,结合了上下界的概念,以剪枝的方式减少搜索范围,确保找到全局最优解。它通常用于解决最优化问题,如旅行商问题。 这五种算法都是计算机科学中解决问题的重要工具,每一种都有其独特的应用场景和优势。了解并熟练掌握这些算法,对于解决实际问题和优化计算效率至关重要。