万本电子书0元读

万本电子书0元读

顶部广告

动手学数据结构与算法电子书

·名家作品:上海交通大学ACM班创始人俞勇教授、翁惠玉教授等编写; ·理论扎实:基于上交大多年的数据结构课程体系编写; ·配套资源丰富:在线代码运行环境 在线视频课程 习题 配套课件 代码实战课程 师资培训课程。 ·可搭配配套代码实战课程学习,跨越理论与实战的鸿沟 ·动手练平台,支持读者在线运行和下载使用代码

售       价:¥

纸质售价:¥70.90购买纸书

13人正在读 | 0人评论 6.4

作       者:俞勇 翁惠玉 傅凌玥 周聪

出  版  社:人民邮电出版社有限公司

出版时间:2024-08-01

字       数:27.7万

所属分类: 科技 > 计算机/网络 > 程序设计

温馨提示:数字商品不支持退换货,不提供源文件,不支持导出打印

为你推荐

  • 读书简介
  • 目录
  • 累计评论(0条)
  • 读书简介
  • 目录
  • 累计评论(0条)
本书系统介绍了数据结构与算法的基本概念和相关知识,既注重理论,又注重算法设计,更突出代码实现,是一本着眼于数据结构与基本算法的教学实践的教材。 本书介绍了线性表、队列与栈、树与优先级队列、集合与静态查找表、动态查找表、排序、外部查找与排序、图、最小生成树与最短路径、算法设计思想等内容,将数据结构的理论与真实应用的实践紧密结合,从各种数据结构的代码实现到火车票管理系统的代码实现,手把手地指导读者学习数据结构与算法,帮助读者轻松掌握数据结构与算法的基本知识及基本技能,为后续行更多专业课程的学习下扎实基础。<br/>【推荐语】<br/>·名家作品:上海交通大学ACM班创始人俞勇教授、翁惠玉教授等编写; ·理论扎实:基于上交大多年的数据结构课程体系编写; ·配套资源丰富:在线代码运行环境 在线视频课程 习题 配套课件 代码实战课程 师资培训课程。 ·可搭配配套代码实战课程学习,跨越理论与实战的鸿沟 ·动手练平台,支持读者在线运行和下载使用代码<br/>【作者】<br/>俞勇,享受国务院特殊津贴专家,首批“国家高层次人才特殊支持计划”教学名师,上海交通大学特聘教授,上海交通大学ACM班创始人,APEX数据与知识管理实验室主任。曾获得“全国模范教师”“全国师德标兵”“CCF杰出教育奖”“上海市五一劳动奖章”和“上海交通大学校长奖”等荣誉。2018年创办了伯禹人工智能学院,在上海交通大学ACM班人工智能专业课程体系的基础上,对人工课程体系行创新,致力于培养卓越的人工智能算法工程师和研究员。翁惠玉,上海交通大学教授,长期担任ACM班程 序设计和数据结构课程的主讲教师,著有“十二五”普通高等教育本科国家级规划教 材《数据结构:思想与实现》(第2版)、工业和信息化部“十四五”规划教材《C 程序——设计思想与方法》(慕课版)(第4版)等。 傅凌?h,上海交通大学博士生,本科毕业于上海交通大学ACM班;担任2019学年ACM班“数据结构”“编程综合实践”课程助教,2022学年工科平台“程序设计思想与方法(C )”课程助教。周聪,上海交通大学博士生,本科毕业于上海交通大学ACM班;担任2020学年ACM班“程序设计”“数据结构”“编程综合实践”课程助教组组长,2021学年ACM班“程序设计”课程助教组组长。<br/>
目录展开

版 权

内容提要

前 言

资源与支持

第1章 绪论

1.1 问题引入

1.2 什么是数据结构

1.2.1 数据的逻辑结构

1.2.2 数据的存储结构

1.2.3 数据的操作

1.3 算法分析

1.3.1 算法的基本概念

1.3.2 时间复杂度

1.3.3 空间复杂度

1.4 算法优化

1.4.1 时间复杂度为O(n3)的算法

1.4.2 时间复杂度为O(n2)的算法

1.4.3 时间复杂度为O(nlogn)的算法

1.4.4 时间复杂度为O(n)的算法

1.5 大型应用实现:火车票管理系统总览

1.6 小结

1.7 习题

第2章 线性表

2.1 问题引入

2.2 线性表的定义

2.3 线性表的实现

2.3.1 线性表的顺序实现

2.3.2 线性表的链接实现

2.4 线性表的简单应用

2.4.1 大整数处理

2.4.2 多项式求和

2.5 大型应用实现:列车运行计划管理类

2.6 小结

2.7 习题

第3章 队列与栈

3.1 问题引入

3.2 队列

3.2.1 队列的定义

3.2.2 队列的顺序实现

3.2.3 队列的链接实现

3.2.4 队列的简单应用:排队洗衣

3.3 栈

3.3.1 栈的定义

3.3.2 栈的顺序实现

3.3.3 栈的链接实现

3.3.4 栈的简单应用:括号匹配

3.4 大型应用实现:排队交易类

3.5 小结

3.6 习题

第4章 树与优先级队列

4.1 问题引入

4.2 树的定义

4.3 二叉树

4.3.1 二叉树的定义

4.3.2 二叉树的顺序实现

4.3.3 二叉树的链接实现

4.3.4 二叉树的简单应用:哈夫曼编码和哈夫曼树

4.4 优先级队列

4.4.1 优先级队列的定义

4.4.2 优先级队列的实现

4.4.3 优先级队列的简单应用:任务调度

4.5 大型应用实现:带优先级的排队交易类

4.6 小结

4.7 习题

第5章 集合与静态查找表

5.1 问题引入

5.2 集合的定义

5.3 静态查找表

5.3.1 无序查找的实现

5.3.2 有序查找的实现

5.4 集合的简单应用:并查集

5.5 大型应用实现:列车运行图类(1)

5.6 小结

5.7 习题

第6章 动态查找表

6.1 问题引入

6.2 动态查找表的定义

6.3 二叉查找树

6.3.1 二叉查找树的定义

6.3.2 二叉查找树的实现

6.4 AVL树

6.4.1 AVL树的定义

6.4.2 AVL树的实现

6.5 红黑树

6.5.1 红黑树的定义

6.5.2 红黑树的实现

6.6 哈希表

6.6.1 哈希表的定义

6.6.2 哈希表的实现

6.7 大型应用实现:旅客管理类

6.8 小结

6.9 习题

第7章 排序

7.1 问题引入

7.2 排序的定义

7.3 插入排序

7.3.1 直接插入排序

7.3.2 二分插入排序

7.3.3 希尔排序

7.4 选择排序

7.4.1 直接选择排序

7.4.2 堆排序

7.5 交换排序

7.5.1 冒泡排序

7.5.2 快速排序

7.6 归并排序

7.7 基数排序

7.8 小结

7.9 习题

第8章 外部查找与排序

8.1 问题引入

8.2 外部查找表的定义

8.3 B树

8.3.1 B树的定义

8.3.2 B树的实现

8.4 B+树

8.4.1 B+树的定义

8.4.2 B+树的实现

8.5 外排序

8.5.1 外排序的定义

8.5.2 外排序的实现

8.6 大型应用实现:余票管理类与行程管理类

8.7 小结

8.8 习题

第9章 图

9.1 问题引入

9.2 图的定义

9.3 图的实现

9.3.1 邻接矩阵

9.3.2 邻接表

9.4 图的遍历

9.4.1 深度优先搜索(DFS)

9.4.2 广度优先搜索(BFS)

9.5 图的遍历的简单应用

9.5.1 图的连通性

9.5.2 欧拉回路

9.5.3 拓扑排序

9.5.4 关键路径

9.6 大型应用实现:列车运行图类(2)

9.7 小结

9.8 习题

第10章 最小生成树与最短路径

10.1 问题引入

10.2 最小生成树

10.2.1 最小生成树的定义

10.2.2 克鲁斯卡尔算法

10.2.3 普里姆算法

10.3 单源最短路径

10.3.1 非加权图的单源最短路径

10.3.2 加权图的单源最短路径

10.3.3 带有负权值图的单源最短路径

10.3.4 无环图的单源最短路径

10.4 所有顶点对的最短路径

10.5 大型应用实现:列车运行图类(3)

10.6 小结

10.7 习题

第11章 算法设计思想

11.1 枚举法

11.2 贪婪算法

11.3 分治法

11.4 回溯法

11.5 动态规划

11.6 随机算法

11.7 算法综合分析:外卖配送任务

11.8 小结

11.9 习题

附录A 书中部分命题的证明

A.1 证明二叉树的性质

A.2 证明两种遍历方法是否能够唯一确定一棵二叉树

A.3 证明AVL树的高度是对数级别的

A.4 证明AVL树插入后至多只需要调整一个结点即可恢复平衡

A.5 证明快速排序的平均时间复杂度为O(nlogn)

A.6 证明归并排序的时间复杂度为O(nlogn)

附录B 电子资源与运行环境配置

B.1 动手练平台

B.2 电子资料仓库

B.3 本地环境搭建和仓库代码运行

B.3.1 Linux环境

B.3.2 Windows环境

B.3.3 macOS环境

累计评论(0条) 0个书友正在讨论这本书 发表评论

发表评论

发表评论,分享你的想法吧!

买过这本书的人还买过

读了这本书的人还在读

回顶部