图书目录

目录

第1章绪论1

1.1算法和算法分析1

1.1.1什么是算法1

1.1.2算法的时间复杂度及其表示法3

1.2数据结构6

1.2.1数据的逻辑结构6

1.2.2数据的存储结构7

1.2.3数据结构上的操作7

小结8

习题8

第2章Java语言巩固与提高10

2.1接口和多态10

2.2内部类和内部接口12

2.3匿名类、Lambda表达式和函数式接口13

2.4泛型16

2.4.1泛型的概念和作用16

2.4.2泛型类、泛型接口和泛型函数17

2.4.3泛型数组22

2.5迭代器22

第3章线性表25

3.1顺序表25

3.1.1顺序表的概念和操作25

3.1.2Java中的顺序表28

3.2链表28

3.2.1单链表29

3.2.2循环单链表32

3.2.3双链表33

3.2.4静态链表36

★★3.2.5Java中的链表37

3.3顺序表和链表的选择39

小结40

习题40

第4章数组和矩阵42

4.1数组42

4.2特殊矩阵的压缩存储45

4.3小结47

4.4习题47

第5章递归和分治49

5.1用递归进行枚举50

5.1.1案例: N皇后问题(P0230)50

5.1.2案例: 全排列(P0240)52

5.2解决用递归形式定义的问题54

5.2.1案例: 波兰表达式(P0250)55

★★5.2.2案例: 绘制雪花曲线56

5.3用递归进行问题分解58

5.3.1案例: 上台阶(P0260)58

5.3.2案例: 数字三角形(P0265)60

5.3.3案例: 算24(P0270)61

5.4分治63

5.4.1案例: 汉诺塔问题(P0310)63

5.4.2案例: 快速幂64

小结65

习题65

第6章栈和队列67

6.1栈67

6.1.1栈的概念和Java中的栈67

6.1.2案例: 括号配对(P0410)68

6.1.3案例: 后序表达式求值(P0420)69

★6.1.4案例: 四则运算表达式求值(P0440)71

6.1.5案例: 合法出栈序列(P0450)73

★★6.2栈和递归的关系75

6.3队列76

6.3.1基本实现76

6.3.2循环队列77

6.3.3Java中的队列80

★6.3.4案例: 用两个栈模拟一个队列81

★★6.3.5案例: 滑动窗口(P0460)82

6.4用链表实现栈和队列84

小结84

习题85

第7章二叉树87

7.1二叉树的概念87

7.2二叉树的性质89

7.3二叉树的表示91

7.3.1用类表示二叉树91

7.3.2完全二叉树的表示92

7.4二叉树的遍历92

7.4.1二叉树的前序、后序、中序和按层次遍历92

7.4.2案例: 根据二叉树前中序序列建树(P0570)95

★7.4.3案例: 求二叉树的宽度(P0630)97

7.4.4案例: 扩展二叉树 (P0700)99

★7.4.5非递归方式遍历二叉树100

★7.5线索二叉树101

7.6堆104

7.6.1堆的概念104

7.6.2堆的操作105

7.6.3建堆107

7.6.4堆的实现和优先队列107

7.7哈夫曼树110

7.7.1哈夫曼树的概念和构造110

7.7.2案例: 栅栏修补(P0590)111

7.7.3哈夫曼编码113

小结115

习题116

第8章树、森林和并查集119

8.1树的概念119

8.2树的实现120

8.2.1树的直观表示法120

8.2.2案例: 括号嵌套树(P0740)121

8.2.3树的儿子兄弟表示法122

8.2.4案例: 树转儿子兄弟树(P0750)123

8.2.5树的父结点表示法125

8.3森林125

8.4并查集126

8.4.1并查集的概念和用途126

8.4.2案例: The Suspects——疑似病人(P0760)128

小结130

习题130

第9章字符串132

9.1字符串的编码132

9.2字符串的实现133

9.3字符串的匹配算法134

9.3.1暴力匹配算法134

★★9.3.2KMP字符串匹配算法135

小结140

习题140

第10章图的遍历和搜索142

10.1图的定义和术语142

10.2图的表示144

10.2.1邻接矩阵144

10.2.2邻接表145

10.2.3邻接表和邻接矩阵的对比146

10.3图的遍历146

10.3.1深度优先遍历146

10.3.2案例: 输出无向图深度优先遍历序列(P1020)148

10.3.3案例: 城堡的房间(P1030)151

10.3.4案例: 判断无向图是否连通及是否有回路(P1040)153

10.3.5广度优先遍历155

10.4图的搜索157

10.4.1概述157

10.4.2深度优先搜索159

10.4.3案例: 走迷宫之一(P1050)162

10.4.4案例: 走迷宫之二(P1060)164

10.4.5案例: 走迷宫之三(P1070)164

10.4.6广度优先搜索166

10.4.7案例: 抓住那头牛(P1080)166

10.4.8案例: “走迷宫之三”的广搜解法(P1070)168

★★10.4.9案例: 拯救行动(P1100)170

10.5深搜和广搜的选择172

小结172

习题173

第11章图论基础应用算法176

11.1最短路176

11.1.1单源最短路问题的Dijkstra算法176

11.1.2案例: 简单的糖果分配(P1220)178

★11.1.3求每对顶点之间最短路的Floyd算法182

★11.1.4案例: 奶牛比赛(P1230)184

11.2最小生成树185

11.2.1概述185

11.2.2最小生成树的性质187

11.2.3Prim算法189

11.2.4Kruskal算法190

★11.2.5案例: 团结真的就是力量(P1235)192

★★11.2.6案例: 北极网络(P1240)196

11.3拓扑排序197

11.3.1拓扑排序的定义和算法197

11.3.2案例: 火星人家族树(P1250)199

★11.4关键路径200

11.4.1关键路径的定义和算法200

★★11.4.2案例: 火星大工程(P1260)203

小结205

习题206

第12章排序208

12.1插入排序209

12.1.1直接插入排序209

12.1.2折半插入排序211

12.1.3希尔排序212

12.2选择排序213

12.2.1简单选择排序213

12.2.2堆排序215

12.3归并排序217

12.4交换排序220

12.4.1冒泡排序220

12.4.2快速排序222

12.5分配排序226

12.5.1桶排序226

12.5.2计数排序227

12.5.3基数排序228

★12.6外排序231

12.6.1置换选择排序231

12.6.2多路归并和败者树235

小结240

习题240

第13章查找243

13.1线性表查找243

13.1.1顺序查找243

13.1.2二分查找244

13.1.3分块查找250

13.2树表查找251

13.2.1二叉查找树251

★13.2.2平衡二叉树(AVL树)259

★13.2.3红黑树264

★13.2.4外存查找: B树和B+树266

13.2.5Java中的二叉查找树274

13.3散列表278

13.3.1散列函数设计279

13.3.2散列表的插入和冲突消解281

13.3.3散列表的删除和查找283

13.3.4散列表的效率分析284

13.3.5Java中的散列表285

小结288

习题290

参考文献294