内容推荐 \t本书是一本综合讲述数据结构及其算法的入门书,力求简洁、清晰、严谨且易于学习和掌握,并没有追求大而全的数据结构和所有相关的算法,而是选择经典的算法来配合介绍常用的数据结构,包括数组、链表、堆栈、队列以及树和图等。
\t本书为每个算法及其数据结构均提供了演算的详细图解,并为每个经典的算法都提供了Python语言编写的完整范例程序(包含完整的源代码)。每个范例程序都经过了测试和调试,可以直接在标准的Python解释器中运行,很好适合作为普及型的教科书或自学读物。
作者简介 \t吴灿铭,现任荣钦科技股份有限公司执行长,美国Rochester Institute of Technology计算机科学研究所毕业,长期从事信息教育及计算机图书写作的工作,计算机图书著作包括计算器概论、数据结构、办公室电子数据处理、互联网等相关题材,并监制过多套游戏以及教学软件的研发。 目录 \t章进入算法的世界1
\t1.1生活中到处都是算法2
\t1.1.1算法的定义3
\t1.1.2算法的条件4
\t1.1.3时间复杂度O(f(n))6
\t1.2常见算法简介7
\t1.2.1分治法8
\t1.2.2递归法9
\t1.2.3贪心法11
\t1.2.4动态规划法12
\t1.2.5迭代法13
\t1.2.6枚举法14
\t1.2.7回溯法15
\t【课后习题】18
\t第2章常用的数据结构19
\t2.1认识数据结构19
\t2.2数据结构的种类22
\t2.2.1数组23
\t2.2.2链表25
\t2.2.3堆栈26
\t2.2.4队列27
\t2.3树形结构28
\t2.3.1树的基本观念29
\t2.3.2二叉树30
\t2.4图形结构简介32
\t2.5哈希表34
\t【课后习题】35
\t第3章排序算法36
\t3.1认识排序37
\t3.2冒泡排序法38
\t3.3选择排序法40
\t3.4插入排序法42
\t3.5希尔排序法44
\t3.6合并排序法46
\t3.7快速排序法49
\t3.8基数排序法51
\t【课后习题】53
\t第4章查找与哈希算法54
\t4.1常见查找算法的介绍55
\t4.1.1顺序查找法55
\t4.1.2二分查找法56
\t4.1.3插值查找法58
\t4.2常见的哈希法简介60
\t4.2.1除留余数法60
\t4.2.2平方取中法62
\t4.2.3折叠法62
\t4.2.4数字分析法63
\t4.3碰撞与溢出问题的处理64
\t4.3.1线性探测法64
\t4.3.2平方探测法65
\t4.3.3再哈希法66
\t【课后习题】67
\t第5章数组与链表算法68
\t5.1矩阵68
\t5.1.1矩阵相加算法69
\t5.1.2矩阵相乘70
\t5.1.3转置矩阵72
\t5.2建立单向链表73
\t5.2.1单向链表的连接功能74
\t5.2.2单向链表的节点删除76
\t5.2.3单向链表的反转79
\t【课后习题】82
\t第6章堆栈与队列算法83
\t6.1用数组实现堆栈83
\t6.2用链表实现堆栈85
\t6.3汉诺塔问题的求解算法87
\t6.4八皇后问题的求解算法93
\t6.5用数组实现队列95
\t6.6用链表实现队列98
\t6.7双向队列100
\t6.8优先队列103
\t【课后习题】104
\t第7章树形结构及其算法105
\t7.1用数组实现二叉树107
\t7.2用链表实现二叉树109
\t7.3二叉树遍历111
\t7.4二叉树节点的查找115
\t7.5二叉树节点的插入116
\t7.6二叉树节点的删除118
\t7.7堆积树排序法121
\t【课后习题】127
\t第8章图的数据结构及其算法129
\t8.1图的遍历129
\t8.1.1深度优先遍历法130
\t8.1.2广度优先遍历法132
\t8.2最小生成树(MST)136
\t8.2.1Prim算法136
\t8.2.2Kruskal算法138
\t8.3图的最短路径法142
\t8.3.1Dijkstra算法与A算法143
\t8.3.2Floyd算法148
\t【课后习题】152
\t附录习题和解答155 |