图书介绍

程序设计解题策略 大学程序设计课程与竞赛训练教材2025|PDF|Epub|mobi|kindle电子书版本百度云盘下载

程序设计解题策略 大学程序设计课程与竞赛训练教材
  • 吴永辉,王建德编著 著
  • 出版社: 北京:机械工业出版社
  • ISBN:9787111488316
  • 出版时间:2015
  • 标注页数:504页
  • 文件大小:58MB
  • 文件页数:516页
  • 主题词:程序设计

PDF下载


点此进入-本书在线PDF格式电子书下载【推荐-云解压-方便快捷】直接下载PDF格式图书。移动端-PC端通用
种子下载[BT下载速度快]温馨提示:(请使用BT下载软件FDM进行下载)软件下载地址页直链下载[便捷但速度慢]  [在线试读本书]   [在线获取解压码]

下载说明

程序设计解题策略 大学程序设计课程与竞赛训练教材PDF格式电子书版下载

下载的文件为RAR压缩包。需要使用解压软件进行解压得到PDF格式图书。

建议使用BT下载工具Free Download Manager进行下载,简称FDM(免费,没有广告,支持多平台)。本站资源全部打包为BT种子。所以需要使用专业的BT下载软件进行下载。如BitComet qBittorrent uTorrent等BT下载工具。迅雷目前由于本站不是热门资源。不推荐使用!后期资源热门了。安装了迅雷也可以迅雷进行下载!

(文件页数 要大于 标注页数,上中下等多册电子书除外)

注意:本站所有压缩包均有解压码: 点击下载压缩包解压工具

图书目录

第1章 利用树型数据关系的解题策略1

1.1 利用划分树求解整数区间内第κ大的值1

1.1.1 离线构建整个查询区间的划分树2

1.1.2 在划分树上查询子区间[ι,r]中第κ大的数3

1.1.3 应用划分树解题4

1.2 利用最小生成树及其扩展形式解题8

1.2.1 最小生成树的思想和应用8

1.2.2 最优比率生成树的思想和应用23

1.2.3 最小κ度限制生成树的思想和应用28

1.2.4 次小生成树的思想和应用35

1.3 利用线段树解决区间计算问题42

1.3.1 线段树的基本概念42

1.3.2 线段树的基本操作和拓展43

1.3.3 应用线段树解题46

1.4 利用改进型的二叉查找树优化动态集合的操作56

1.4.1 改进型1:伸展树57

1.4.2 改进型2:红黑树60

1.4.3 应用改进型的二叉查找树解题64

1.5 利用动态树维护森林的连通性81

1.5.1 动态树的问题背景81

1.5.2 L.ink-CutTree的定义82

1.5.3 Link-CutTree的基本操作和时间复杂度分析82

1.5.4 应用动态树解题85

1.6 利用左偏树实现优先队列的合并95

1.6.1 左偏树的定义和性质95

1.6.2 左偏树的操作97

1.6.3 应用左偏树解题103

1.7 利用跳跃表替代树结构106

1.7.1 跳跃表的基本概念107

1.7.2 跳跃表的基本操作107

1.7.3 跳跃表的效率分析109

1.7.4 应用跳跃表解题111

本章小结126

第2章 利用图型数据关系的解题策略128

2.1 利用网络流算法解题128

2.1.1 网络、流与割的概念128

2.1.2 利用Dinic算法计算最大流132

2.1.3 求容量有上下界的最大流问题145

2.1.4 计算最小费用最大流155

2.2 利用图的匹配算法解题161

2.2.1 匹配的基本概念161

2.2.2 计算二分图的最大匹配166

2.2.3 计算二分图最佳匹配的KM算法167

2.2.4 利用一一对应的匹配性质转化问题的实验范例179

2.3 利用分层图思想解题191

2.3.1 利用分层图思想化未知为已知191

2.3.2 利用分层图思想优化算法的实验范例195

2.4 利用平面图性质解题199

2.4.1 平面图的基本概念199

2.4.2 平面图的实验范例200

2.4.3 偏序集的基本概念210

2.4.4 偏序集的实验范例211

2.5 在充分挖掘和利用图论模型性质的基础上优化算法216

2.5.1 优化图论模型的三种方法216

2.5.2 三种优化方法的实验范例217

本章小结224

第3章 数据关系上的构造策略226

3.1 选择数据逻辑结构的基本原则226

3.1.1 充分利用“可直接使用”的信息226

3.1.2 不记录“无用”的信息230

3.2 选择数据存储结构的基本方法235

3.2.1 合理采用顺序存储结构235

3.2.2 必要时采用链式存储结构239

3.3 科学组合多种数据结构245

3.3.1 数据结构的“并联”246

3.3.2 数据结构的“嵌套”252

本章小结259

第4章 数据统计上的二分策略260

4.1 利用线段树统计数据260

4.1.1 利用线段树解决一维数据序列的统计问题260

4.1.2 利用线段树解决二维数据区的统计问题264

4.2 基于数组统计方法268

4.2.1 利用树状数组解决动态统计子序列和问题269

4.2.2 采用倍增算法求解RMQ问题274

4.3 在静态二叉排序树上统计数据284

4.3.1 建立静态二叉排序树285

4.3.2 在静态二叉排序树上进行统计285

4.3.3 静态二叉排序树的应用287

4.4 在虚二叉树上统计数据291

本章小结297

第5章 动态规划上的优化策略298

5.1 减少状态总数的基本策略298

5.1.1 改进状态表示298

5.1.2 选择适当的DP方向302

5.2 减少每个状态决策数的基本策略307

5.2.1 利用最优决策的单调性307

5.2.2 剪枝优化315

5.2.3 合理组织状态327

5.2.4 细化状态转移335

5.3 减少状态转移时间的基本策略340

5.3.1 减少决策时间340

5.3.2 减少计算递推式的时间349

5.4 应对连通性问题的DP策略——基于状态压缩的插头DP353

5.4.1 插头DP的一般模式353

5.4.2 用于简单路径问题上的插头DP361

5.4.3 用于棋盘染色问题上的插头DP365

5.4.4 插头DP中的剪枝优化373

本章小结380

第6章 计算几何上的应对策略382

6.1 用于求解距离问题的模拟退火算法382

6.1.1 模拟退火算法的由来382

6.1.2 模拟退火算法的实现383

6.1.3 模拟退火算法的应用范例384

6.2 用于求解凸性函数极值问题的三分法393

6.2.1 三分法的基本思想393

6.2.2 三分法的应用范例394

6.3 使用剖分优化应对复合属性的几何图形398

6.3.1 圆重合其他几何图形时的剖分策略398

6.3.2 使用三角剖分思想计算几何图形面积413

6.3.3 使用梯形剖分计算多边形面积420

6.3.4 利用矩形切割思想进行几何计算和数据统计425

6.4 利用极大化思想解决最大子矩形问题432

6.4.1 与极大化思想有关的概念432

6.4.2 寻找最大子矩形的两种常用算法432

6.4.3 最大子矩形问题的推广436

6.4.4 利用极大化思想解决最大子矩形问题的范例437

6.5 在求解综合性、扩展性几何问题中合理组合基本几何运算444

6.5.1 在复杂的综合性试题中合理组合基本几何运算445

6.5.2 在空间几何计算中合理组合基本几何运算455

本章小结461

第7章 博弈类问题的应对策略462

7.1 利用动态博弈思想判断输赢462

7.2 基础性博弈中的对抗策略467

7.2.1 巴什博弈468

7.2.2 威佐夫博弈469

7.2.3 尼姆博弈471

7.3 基础性博弈扩展形式中的对抗策略477

7.3.1 巴什博弈的扩展——κ倍动态减法游戏477

7.3.2 尼姆博弈的四种扩展形式481

7.4 使用SG函数应对一类组合游戏485

7.4.1 SG-组合游戏问题的特殊性质485

7.4.2 “翻硬币”游戏487

7.4.3 多图游戏491

7.5 使用数学工具surreal number应对不平等的组合游戏498

7.5.1 数学工具surreal number498

7.5.2 surreal number在组合游戏上的应用500

本章小结503

热门推荐