本书采用丰富的图例来阐述基本概念,并以简洁清晰的语言来诠释重要的理论和算法,同时配合完整的范例程序代码,使读者可以通过“实例 实践”来熟悉数据结构。 本书内容共9章,先从基本的数据结构概念开始介绍,再以Python语言来实现数组、堆栈、链表、队列、树、图、排序、查找等重要的数据结构。在附录A提供了Python语言的快速入门,附录B是使用Python语言实现数据结构程序时调试经验的分享,附录C则提供了所有课后习题的答案。 现任荣钦科技股份有限公司执行长,美国Rochester Institute of Technology计算机科学研究所毕业,长期从事信息教育及计算机图书写作的工作,计算机图书著作包括计算器概论、数据结构、办公室电子数据处理、互联网等相关题材,并监制过多套游戏以及教学软件的研发。 目 录第1章 数据结构导论 11.1 数据结构的定义 21.1.1 数据与信息 21.1.2 数据的特性 31.1.3 数据结构的应用 31.2 算法 51.3 认识程序设计 71.3.1 程序开发流程 81.3.2 结构化程序设计 81.3.3 面向对象程序设计 91.4 算法性能分析 111.4.1 Big-Oh 121.4.2 Ω 151.4.3 θ 15【课后习题】 15第2章 数组结构 172.1 线性表简介 182.2 认识数组 192.2.1 二维数组 212.2.2 三维数组 252.2.3 n维数组 272.3 矩阵 282.3.1 矩阵相加 282.3.2 矩阵相乘 292.3.3 转置矩阵 312.3.4 稀疏矩阵 322.3.5 上三角形矩阵 352.3.6 下三角形矩阵 392.3.7 带状矩阵 432.4 数组与多项式 44【课后习题】 46第3章 链表 483.1 单向链表 493.1.1 建立单向链表 503.1.2 遍历单向链表 513.1.3 在单向链表中插入新节点 533.1.4 在单向链表中删除节点 583.1.5 单向链表的反转 613.1.6 单向链表的连接功能 643.1.7 多项式链表表示法 693.2 环形链表 713.2.1 环形链表的建立与遍历 723.2.2 在环形链表中插入新节点 743.2.3 在环形链表中删除节点 783.2.4 环形链表的连接功能 823.2.5 环形链表与稀疏矩阵表示法 853.3 双向链表 863.3.1 双向链表的建立与遍历 873.3.2 在双向链表中插入新节点 913.3.3 在双向链表中删除节点 95【课后习题】 99第4章 堆栈 1014.1 堆栈简介 1024.1.1 用列表实现堆栈 1034.1.2 用链表实现堆栈 1074.2 堆栈的应用 1104.2.1 递归算法 1114.2.2 汉诺塔问题 1154.2.3 老鼠走迷宫 1204.2.4 八皇后问题 1254.3 算术表达式的表示法 1284.3.1 中序法转为前序法与后序法 1294.3.2 前序法与后序法转为中序法 1354.3.3 中序法表达式的求值运算 1374.3.4 前序法表达式的求值运算 1384.3.5 后序法表达式的求值运算 139【课后习题】 140第5章 队列 1435.1 认识队列 1445.1.1 队列的基本操作 1445.1.2 用数组实现队列 1455.1.3 用链表实现队列 1485.2 队列的应用 1515.2.1 环形队列 1515.2.2 双向队列 1555.2.3 优先队列 159【课后习题】 160第6章 树形结构 1616.1 树的基本概念 1626.2 二叉树简介 1646.2.1 二叉树的定义 1656.2.2 特殊二叉树简介 1666.3 二叉树的存储方式 1676.3.1 一维数组表示法 1676.3.2 链表表示法 1706.4 二叉树遍历 1726.4.1 中序遍历 1736.4.2 后序遍历 1736.4.3 前序遍历 1736.4.4 二叉树节点的插入与删除 1786.4.5 二叉运算树 1846.5 线索二叉树 1896.6 树的二叉树表示法 1956.6.1 树转化为二叉树 1956.6.2 二叉树转换成树 1966.6.3 森林转换为二叉树 1976.6.4 二叉树转换成森林 1986.6.5 树与森林的遍历 1996.6.6 确定唯一二叉树 2016.7 优化二叉查找树 2026.7.1 扩充二叉树 2026.7.2 霍夫曼树 2046.7.3 平衡树 2056.8 B树 210【课后习题】 212第7章 图形结构 2167.1 图形简介 2177.1.1 欧拉环与欧拉链 2177.1.2 图形的定义 2187.1.3 无向图 2187.1.4 有向图 2197.2 图的数据表示法 2207.2.1 邻接矩阵法 2207.2.2 邻接表法 2247.2.3 邻接复合链表法 2267.2.4 索引表格法 2287.3 图的遍历 2307.3.1 深度优先遍历法 2307.3.2 广度优先遍历法 2337.4 生成树 2377.4.1 DFS生成树和BFS生成树 2387.4.2 最小生成树 2397.4.3 Kruskal算法 2397.5 图的最短路径 2447.5.1
阅读更多
漫游鲸二手书店
微信扫码去买书
扫码访问微信小程序