内容推荐 本书共8章,主要从算法的分析与设计两个方面进行介绍。首先,系统地介绍了算法分析的基本方法,包括非递归算法和递归算法,并详细介绍了Master定理。然后,系统地介绍了各种算法设计策略,包括分治策略、动态规划算法、贪心算法、回溯法、分支限界法、线性规划与网络流等。对于每种算法设计策略,从该策略的基本思想、适用问题、算法步骤或框架、应用范例等多个方面详细讲解,对于复杂的算法设计策略还给出了相关例题。书中包含大量的范例和对应的实现代码,让读者对算法设计策略的基本思想和核心设计步骤有深入的理解与掌握,能够让读者掌握各种算法设计策略的精髓,能够提高读者的算法设计能力,能够让读者具备分析具体问题、选择算法设计策略、给出算法代码的能力。 本书主要作为普通高校教材,适用于计算机科学与技术相关专业的本科和研究生阶段的教材,也可以作为从事实际问题求解的研究工作者的入门教材。 目录 第1章 算法概述 1.1 引言 1.2 算法的概念 1.3 算法复杂性分析 1.4 本章小结 习题 第2章 递归与分治策略 2.1 递归 2.2 分治策略 2.3 分治法求解查找问题 2.4 分治法求解排序问题 2.5 分治法求解复杂计算问题 2.6 分治法求解组合问题 2.7 本章小结 习题 第3章 动态规划算法 3.1 动态规划的基本概念 3.2 备忘录方法 3.3 动态规划算法的总体设计思想和 基本要素 3.4 矩阵连乘问题 3.5 最长公共子序列问题 3.6 0-1背包问题 3.7 最大子段和问题 3.8 凸多边形最优三角剖分 3.9 本章小结 习题 第4章 贪心算法 4.1 生活中的贪心算法 4.2 贪心算法的基本思想 4.3 活动安排问题 4.4 最优装载问题 4.5 哈夫曼编码 4.6 贪心算法的正确性验证 4.7 本章小结 习题 第5章 回溯法 5.1 回溯法的基本思想 5.2 回溯法的算法框架 5.3 装载问题 5.4 批处理作业调度问题 5.5 符号三角形问题 5.6 0-1背包问题 5.7 最大团问题 5.8 旅行商问题 5.9 连续邮资问题 5.10 回溯法的效率分析 5.11 本章小结 习题 第6章 分支限界法 6.1 分支限界法的基本思想 6.2 装载问题 6.3 布线问题 6.4 0-1背包问题 6.5 最大团问题 6.6 旅行商问题 6.7 本章小结 习题 第7章 随机算法 7.1 随机算法的设计思想 7.2 随机数发生器 7.3 数值随机算法 7.4 舍伍德算法 7.5 拉斯维加斯算法 7.6 蒙特卡罗算法 7.7 本章小结 习题 第8章 线性规划与网络流 8.1 线性规划概述 8.2 单纯形法的设计思想与步骤 8.3 单纯形法的描述与分析 8.4 网络最大流问题 8.5 最小费用流问题 8.6 本章小结 习题 参考文献 |