当前位置: 首页 > 编程日记 > 正文

资料分享:送你一本《数据结构(C语言版)》电子书!

要想写出可复用、可扩展、易维护、灵活性好的代码,「数据结构」这一关必须要过啊!

在数据结构与算法的众多教材中,奉为经典的当属清华大学严蔚敏老师的著作。很多学校也选择这本书作为考研指定教材。

正在学习数据结构与算法这门课程的同学 或者 有意愿精进自己代码编写水平的小伙伴,可以下载这本电子书来看看。


目录

第1章 绪论

  • 1.1 什么是数据结构
  • 1.2 基本概念和术语
  • 1.3 抽象数据类型的表示与实现
  • 1.4 算法和算法分析
  • 算法
  • 算法设计的要求
  • 算法效率的度量
  • 算法的存储空间需求

第2章 线性表

  • 2.1 线性表的类型定义
  • 2.2 线性表的顺序表示和实现
  • 2.3 线性表的链式表示和实现
  • 线性链表
  • 循环链表
  • 双向链表
  • 2.4 一元多项式的表示及相加

第3章 栈和队列

  • 3.1 栈
  • 抽象数据类型栈的定义
  • 栈的表示和实现
  • 3.2 栈的应用举例
  • 数制转换
  • 括号匹配的检验
  • 行编辑程序
  • 迷宫求解
  • 表达式求值
  • 3.3 栈与递归的实现
  • 3.4 队列
  • 抽象数据类型队列的定义
  • 链队列——队列的链式表示和实现
  • 循环队列——队列的顺序表示和实现
  • 3.5 离散事件模拟

第4章 串

  • 4.1 串类型的定义
  • 4.2 串的表示和实现
  • 定长顺序存储表示
  • 堆分配存储表示
  • 串的块链存储表示
  • 4.3 串的模式匹配算法
  • 求子串位置的定位函数index(s,t,pos)
  • 模式匹配的一种改进算法
  • 4.4 串操作应用举例
  • 文本编辑
  • 建立词索引表

第5章 数组和广义表

  • 5.1 数组的定义
  • 5.2 数组的顺序表示和实现
  • 5.3 矩阵的压缩存储
  • 特殊矩阵
  • 稀疏矩阵
  • 5.4 广义表的定义
  • 5.5 广义表的存储结构
  • 5.6 m元多项式的表示
  • 5.7 广义表的递归算法
  • 求广义表的深度
  • 复制广义表
  • 建立广义表的存储结构

第6章 树和二叉树

  • 6.1 树的定义和基本术语
  • 6.2 二叉树
  • 二叉树的定义
  • 二叉树的性质
  • 二叉树的存储结构
  • 6.3 遍历二叉树和线索二叉树
  • 遍历二叉树
  • 线索二叉树
  • 6.4 树和森林
  • 树的存储结构
  • 森林与二叉树的转换
  • 树和森林的遍历
  • 6.5 树与等价问题
  • 6.6 赫夫曼树及其应用
  • 最优二叉树(赫夫曼树)
  • 赫夫曼编码
  • 6.7 回溯法与树的遍历
  • 6.8 树的计数

第7章 图

  • 7.1 图的定义和术语
  • 7.2 图的存储结构
  • 数组表示法
  • 邻接表
  • 十字链表
  • 邻接多重表
  • 7.3 图的遍历
  • 深度优先搜索
  • 广度优先搜索
  • 7.4 图的连通性问题
  • 无向图的连通分量和生成树
  • 有向图的强连通分量
  • 最小生成树
  • 关节点和重连通分量
  • 7.5 有向无环图及其应用
  • 拓扑排序
  • 关键路径
  • 7.6 最短路径
  • 从某个源点到其余各顶点的最短路径
  • 每一对顶点之间的最短路径

第8章 动态存储管理

  • 8.1 概述
  • 8.2 可利用空间表及分配方法
  • 8.3 边界标识法
  • 可利用空间表的结构
  • 分配算法
  • 回收算法
  • 8.4 伙伴系统
  • 可利用空间表的结构
  • 分配算法
  • 回收算法
  • 8.5 无用单元收集
  • 8.6 存储紧缩

第9章 查找

  • 9.1 静态查找表
  • 顺序表的查找
  • 有序表的查找
  • 静态树表的查找
  • 索引顺序表的查找
  • 9.2 动态查找表
  • 二叉排序树和平衡二叉树
  • b-树和b+树
  • 键树
  • 9.3 哈希表
  • 什么是哈希表
  • 哈希函数的构造方法
  • 处理冲突的方法
  • 哈希表的查找及其分析

第10章 内部排序

  • 10.1 概述
  • 10.2 插入排序
  • 直接插入排序
  • 其他插入排序
  • 希尔排序
  • 10.3 快速排序
  • 10.4 选择排序
  • 简单选择排序
  • 树形选择排序
  • 堆排序
  • 10.5 归并排序
  • 10.6 基数排序
  • 多关键字的排序
  • 链式基数排序
  • 10.7 各种内部排序方法的比较讨论

第11章 外部排序

  • 11.1 外存信息的存取
  • 11.2 外部排序的方法
  • 11.3 多路平衡归并的实现
  • 11.4 置换 选择排序
  • 11.5 最佳归并树

第12章 文件

  • 12.1 有关文件的基本概念
  • 12.2 顺序文件
  • 12.3 索引文件
  • 12.4 isam文件和vsam文件
  • isam文件
  • vsam文件
  • 12.5 直接存取文件(散列文件)
  • 12.6 多关键字文件
  • 多重表文件
  • 倒排文件

附录a 名词索引

附录b 函数索引

参考书目


推荐阅读

  • 如何利用 C# 爬取「京东 - 计算机与互联网图书销量榜」!
  • 如何利用 C# 爬取「当当 - 计算机与互联网图书销量榜」!
  • 如何利用 C# 爬取「互动出版网 - 计算机图书销量榜」!

下载《数据结构(C语言版)》

关注公众号,后台回复

20190327


相关文章:

零基础学python培训需要学习多久?

Python是一种入门比较简单的编程语言,但是如果是零基础学员,学习起来还是需要时间的,那么零基础学python培训需要学习多久呢?我们来看看小编的详细介绍吧。 零基础学python培训需要学习多久? 现在的培训机构,一般Python的培训时…

拖动无标题窗体

方法一: 当用户点击窗体的时候欺骗系统,用户是点在标题栏上,这样就完成了无标题栏窗体的拖动,实现如下: 在 MESSAGE_HANDLER(WM_NCHITTEST, OnNcHitTest) 这个函数的方法里 : LRESULT CNyWnd::OnNcHitTest(…

如何利用 C# 爬取Gate.io交易所的公告!

对于大部分程序员来说,都希望自己或多或少拥有一些比特币(BTC)。获取 BTC 的途径除了挖矿计算 Hash 值之外,就是去交易所购买了。 由于 BTC 的价格波动非常剧烈,入手 BTC 的时机就显得尤为关键。在交易所搞活动时入手…

人的原罪、本我和超我

摘自:https://www.zhihu.com/question/31362451/answer/51606300人的原罪的存在,因为人人皆有,所以在潜意识中,形成了对本我的接纳,而神爱世人与宽恕的存在,形成了本我与超我的良性互动。 在这样的关系中&a…

软件测试的准入准出是什么?标准是什么?

测试的准入准出是指什么情况下可以开始当前版本的测试工作,什么情况下可以结束当前版本的测试工作。不同项目、不同公司的测试准入准出标准都会有所不同。下面介绍一些通用的测试准入准出标准。 测试准入标准如下: (1)开发编码结束,开发人员在…

如何利用 C# 爬取 One 持有者返利数据!

去年,10月份写过一篇图文 「One」的投资价值分析,多半年过去了,回头看看当时的判断还是合理的。 投资这种事情需要有自己的策略,更需要理性。任何决策都需要以数据作为判断的基础,哪么是否还继续持有 ONE呢&#xff1f…

04.微博消息的语言检测

04.微博消息的语言检测 郑昀 201010 隶属于《02.数据解析》小节 大意是,封装Google语言检测ajax web service的接口,输入一段话,输出语言种类。这个方法是从RssMeme.com看来的,经测试效果还不错,可用于检测微博客消息的…

CIO时代学院院长姚乐:传统行业遇上大数据 拥抱智能化未来

近几年,互联网行业发展突飞猛进,“大数据”技术瞬间变得炙手可热,当然,对于发展中的大数据技术而言,很多行业都不会错失良机。近日,CIO时代学院院长、中国新一代IT产业推进联盟秘书长姚乐在“2016CIO时代中…

自动化测试的优势和局限性有哪些

自动化测试只是众多测试中的一种,并不比人工测试更高级更先进。和人工测试相比自动化测试有一定的优势和劣势,具体如下。 1.优势 (1)自动化测试具有一致性和重复性的特点,而且测试更客观,提高了软件测试的准确度、精确度和可信任度…

也分享一个存储过程代码生成器 开源

可以通过 FILE>OPTION 修改前缀,作者等信息。。。。。 完全傻瓜式应用,开源,方便进行个性化开发。。。 工具地址:http://spgen.codeplex.com/ Stored Procedure Generator (for SQL Server 2000/2005) 虽然这样写,但…

如何利用 C# 爬取BigOne交易所的公告!

在当今这个时代,投资可以说是每个人都应该学会的一项技能。拥有一些数字货币是程序员的信仰!交易所是进入数字货币世界最方便的一扇门,今天我就带着大家爬取 Bigone 交易所的公告数据。 首先,我们来看一下要爬取的页面以及对应的…

如何提升自己的Web前端技术

如何提升自己的Web前端技术?问这个问题的一般都是有一些web基础的同学,还有一部分是自学的web前端技术,对自己目前的能力还比较模糊,下面小编就这个问题为大家做下详细的介绍。 如何提升自己的Web前端技术?在IT行业,任何一种专业…

tomcat 性能设置

Tomcat性能调优: 找到Tomcat根目录下的conf目录,修改server.xml文件的内容。对于这部分的调优,我所了解到的就是无非设置一下Tomcat服务器的最大并发数和Tomcat初始化时创建的线程数的设置,当然还有其他一些性能调优的设置&#x…

SAP的安装后基本设定

SAPLogon登录时候是乱码,设定登陆配置的代码页属性,勾选Unicode off SAP英文系统下中文显示乱码 设定字符集为GB2312 RZ10常用的配置参数rz10 编辑系统参数文件 rdisp/gui_auto_logout & rdisp/keepalive 用于控制闲置时间(秒) login/system_client 用于控制默认…

如何通过 Scratch 教小朋友编程思维?

寒假的时候,我带着自己的小孩学 Scratch,希望通过这种图形化的语言来训练他的编程思维。开学之后,很多事情需要处理,所以拖到现在才写总结。希望对大家有所启发。 在介绍如何做这件事情之前,先介绍一个学习方面的基本…

零基础怎么学习UI设计?有哪些简单的学习方法?

UI设计近几年的就业前景是非常好的,所以很多人都想要学习UI设计,那么零基础怎么学习UI设计?有哪些简单的学习方法?下面小编就给大家做下详细的介绍。 零基础怎么学习UI设计?有哪些简单的学习方法? UI设计行业是很注重技术的,零基础如果直…

让资源管理器不显示最近常用文件夹

右键点任务栏,点“属性”->Startmenu->在Privacy框中,把第二个√ 去掉,如下图所示:

C# 写Windows服务

服务是一个运行在后台的程序,他没有界面,不能交互,只能孤独的独自运行。 在开始->运行->输入services.msc可以打开服务管理器,这里可以查看和管理服务   很多时候都会用到服务,因为服务简化了我们的操作&#…

技术图文:如何利用 C# 爬取 ONE 的交易数据?

投资一个金融产品,最基本的就是拿到这个金融产品的交易数据,对这些数据进行可视化来判断趋势。去年,我在听 李笑来 讲区块链的课程上知道了 BigOne 这个由 INB 投资的交易所,而 ONE 是 BigOne 的平台币,持有 ONE 可享受…

java程序猿必读的学习书籍,良心推荐!

每年都有很多人想要学习java技术,有的是自学,有的是报班学习,但是都免不了要看书籍学习,书籍学习带来的知识更加牢记,也可以随时做笔记,下面小编就为大家推荐java程序猿必读的学习书籍,希望能帮…

Autools学习总结(一)

一、Makefile 简介 在编写C/C程序的时候,我们经常需要编译并运行代码。在程序规模较小的情况下,可以简单地直接调用编译器来完成这项工作。然而,在很多情况下程序往往包括大量的代码文件,手动调用编译器变得麻烦无比。尤其要命的是…

简单的实现IOCP服务器模型

其实已经有很多大佬将原理讲的十分详细了,所以就不花费时间将原理再一次重复讲一遍,有需要的可以自行去查看。 http://blog.csdn.net/beyond_cn/article/details/9336043 这篇文章是我看的,原理介绍十分详细。不过有一些操作感觉比较复杂因此…

资料分享:送你一本《数据结构与算法JavaScript描述》电子书!

数据结构 是掌握计算机编程必须具备的技能。通常情况下,我想掌握一门编程语言所用的方法就是利用这门语言把数据结构中线性表、栈、队列、字符串、动态数字、整数集合、树、图、搜索、排序等涉及的算法全部写一遍。写完之后,基本上就把这门语言搞定了。 …

Python中爬虫框架或模块的区别

Python中爬虫框架或模块的区别,我们在Python的学习过程中,需要不断的总结知识点,这样我们才能进步的更快一些。 (1)爬虫框架或模块 Python自带爬虫模块:urllib、urllib2; 第三方爬虫模块:requests,aiohttp;…

SQL SERVER 2000写存储过程出现列名无效的解决方法

举一个Northwind的例子。DECLARE m_LastName nvarchar(20) DECLARE Sql varchar(256)SET m_LastName Fuller SET Sql SELECT * FROM Employees WHERE LastName char(39) m_LastName char(39) EXEC(Sql) 注意,要加上char(39)就可以了。转载于:https://www.cnblo…

如何利用 C# + Python 破解猫眼电影的反爬虫机制?

在 如何利用 C# 爬取「猫眼电影:最受期待榜」及对应影片信息! 这篇图文中可以看到猫眼电影对“本月新增想看人数” 和 “总想看人数”进行了字符集加密。 在 如何利用 C# 爬取「猫眼电影:国内票房榜」及对应影片信息! 这篇图文中也…

ZooKeeper学习笔记1-----------安装启动

ZooKeeper是一套协作服务,主要用来构建分布式架构的应用,通过ZooKeeper我们可以安全的处理分布式应用下的局部故障问题。我们知道ZooKeeper就是Hadoop中的分布式协作服务组件。下面我们进入ZooKeeper的安装部署。 安装Zookeeper https://zookeeper.apach…

软件测试培训完就业方向怎么选择

软件测试技术在近几年的发展前景是非常好的,越来越多的人都想要学习软件测试技术,报班是大多数人的选择,但是大家对于“软件测试培训完就业方向怎么选择”这个问题比较迷茫,我们来看看下面的详细介绍。 软件测试培训完就业方向怎么…

LeetCode实战:合并两个有序链表

题目英文: Merge two sorted linked lists and return it as a new list. The new list should be made by splicing together the nodes of the first two lists. Example: Input: 1->2->4, 1->3->4 Output: 1->1->2->3->4->4 题目中…

Apache反向代理设置【转载】

编译Apache时要进行的设置./configure --enable-mods-shared"all proxy"1>修改 httpd.conf 文件中:LoadModule proxy_module modules/mod_proxy.soLoadModule proxy_connect_module modules/mod_proxy_connect.soLoadModule proxy_http_module modules…