登录/注册
下载豆瓣客户端

豆瓣

扫码直接下载

豆瓣读书
搜索:

数据结构与算法分析

作者: Mark Allen Weiss (维斯)
出版社: 机械工业出版社
副标题: C语言描述
原作名: Data Structures and Algorithm Analysis in C:Second Edition
译者: 冯舜玺
出版年: 2004年1月1日
页数: 391
定价: 35.00元
装帧: 平装
丛书: 计算机科学丛书
ISBN: 9787111127482
豆瓣评分
5星 57.0%
4星 33.1%
3星 7.7%
2星 1.1%
1星 1.0%
评价:

内容简介 · · · · · ·

数据结构与算法分析的创作者 · · · · · ·

作者简介 · · · · · ·

Mark Allen Weiss,1987年在普林斯顿大学获得计算机科学博士学位,师从Robert Sedgewick (师从Knuth),现任美国佛罗里达国际大学计算与信息科学学院教授。他曾经担任全美AP(Advanced Placement)考试计算机学科委员会的主席(2000-2004)。他的主要研究方向是数据结构、算法和教育学。

目录 · · · · · ·

第1章 引论
1.1 本书讨论的内容
1.2 数学知识复习
1.2.1 指数
1.2.2 对数
1.2.3 级数
· · · · · · ()
第1章 引论
1.1 本书讨论的内容
1.2 数学知识复习
1.2.1 指数
1.2.2 对数
1.2.3 级数
1.2.4 模运算
1. 2.5 证明方法
1.3 递归简论
总结
练习
参考文献
第2章 算法分析
2.1 数学基础
2.2 模型
2.3 要分析的问题
2.4 运行时间计算
2.4.1 一个简单的例子
2.4.2 一般法则
2.4.3 最大子序列和问题的解
.2.4.4 运行时间中的对数
2.4.5 检验你的分析
2.4.6 分析结果的准确性
总结
练习
参考文献
第3章 表、栈和队列
3.1 抽象数据类型(adt)
3.2 表adt
3.2.1 表的简单数组实现
3.2.2 链表
3.2.3 程序设计细节
3.2.4 常见的错误
3.2.5 双链表
3.2.6 循环链表
3.2.7 例子
3.2.8 链表的游标实现
3.3 栈adt
3.3.1 栈模型
3.3.2 栈的实现
3.3.3 应用
3.4 队列adt
3.4.1 队列模型
3.4.2 队列的数组实现
3.4.3 队列的应用
总结
练习
第4章 树
4.1 预备知识
4.1.1 树的实现
4.1.2 树的遍历及应用
4.2 二叉树
4.2.1 实现
4.2.2 表达式树
4.3 查找树adt--二叉查找树
4.3.1 makeempty
4.3.2 find
4.3.3 findmin和findmax
4.3.4 insert
4.3.5 delere
4.3.6 平均情形分析
4.4 avl树
4.4.1 单旋转
4.4.2 双旋转
4.5 伸展树
4.5.1 一个简单的想法
4.5.2 展开
4.6 树的遍历
4.7 b-树
总结
练习
参考文献
第5章 散列
5.1 一般想法
5.2 散列函数
5.3 分离链接法
5.4 开放定址法
5.4.1 线性探测法
5.4.2 平方探测法
5.4.3 双散列
5.5 再散列
5.6 可扩散列
总结
练习
参考文献
第6章 优先队列(堆)
6.1 模型
6.2 一些简单的实现
6.3 二叉堆
6.3.1 结构性质
6.3.2 堆序性质
6.3.3 基本的堆操作
6.3.4 其他的堆操作
6.4 优先队列的应用
6.4.1 选择问题
6.4.2 事件模拟
6.5 d-堆
6.6 左式堆
6.6.1 左式堆的性质
6.6.2 左式堆的操作
6.7 斜堆
6.8 二项队列
6.8.1 二项队列结构
6.8.2 二项队列操作
6.8.3 二项队列的实现
总结
练习
参考文献
第7章 排序
7.1 预备知识
7.2 插入排序
7.2.1 算法
7.2.2 插入排序的分析
7.3 一些简单排序算法的下界
7. 4 希尔排序
7.4.1 希尔排序的最坏情形分析
7.5 堆排序
7.5.1 堆排序的分析
7.6 归并排序
7.6.1 归并排序的分析
7.7 快速排序
7.7.1 选取枢纽元
7.7.2 分割策略
7.7.3 小数组
7.7.4 实际的快速排序例程
7.7.5 快速排序的分析
7.7.6 选择的线性期望时间算法
7.8 大型结构的排序
7.9 排序的一般下界
7.9.1 决策树
7.10 桶式排序
7.11 外部排序
7.11.1 为什么需要新的算法
7.11.2 外部排序模型
7.11.3 简单算法
7.11.4 多路合并
7.11.5 多相合并
7.11.6 替换选择
总结
练习
参考文献
第8章 不相交集adt
8.1 等价关系
8.2 动态等价性问题
8.3 基本数据结构
8.4 灵巧求并算法
8.5 路径压缩
8.6 按秩求并和路径压缩的最坏情形
8.6.1 union/find算法分析
8.7 一个应用
总结
练习
参考文献
第9章 图论算法
9.1 若干定义
9.1.1 图的表示
9.2 拓扑排序
9.3 最短路径算法
9.3.1 无权最短路径
9.3.2 dijkstra算法
9.3.3 具有负边值的图
9.3.4 无圈图
9.3.5 所有点对最短路径
9.4 网络流问题
9.4.1 一个简单的最大流算法
9.5 最小生成树
9.5.1 prim算法
9.5.2 kruskal算法
9.6 深度优先搜索的应用
9.6.1 无向图
9.6.2 双连通性
9.6.3 欧拉回路
9.6.4 有向图
9.6.5 查找强分支
9.7 np-完全性介绍
9.7.1 难与易
9.7.2 np类
9.7.3 np-完全问题
总结
练习
参考文献
第10章 算法设计技巧
10.1 贪婪算法
10.1.1 一个简单的调度问题
10.1.2 huffman编码
10.1.3 近似装箱问题
10.2 分治算法
10.2.1 分治算法的运行时间
10.2.2 最近点问题
10.2.3 选择问题
10.2.4 一些运算问题的理论改进
10.3 动态规划
10.3.1 用一个表代替递归
10.3.2 矩阵乘法的顺序安排
10.3.3 最优二叉查找树
10.3.4 所有点对最短路径
10.4 随机化算法
10.4.1 随机数发生器
10.4.2 跳跃表
10.4.3 素性测试
10.5 回溯算法
10.5.1 收费公路重建问题
10.5.2 博弈
总结
练习
参考文献
第11章 摊还分析
11.1 一个无关的智力问题
11.2 二项队列
11.3 斜堆
11.4 斐波那契堆
11.4.1 切除左式堆中的节点
11.4.2 二项队列的懒惰合并
11.4.3 斐波那契堆操作
11.4.4 时间界的证明
11. 5 伸展树
总结
练习
参考文献
第12章 高级数据结构及其实现
12.1 自顶向下伸展树
12.2 红黑树
12.2.1 自底向上插入
12.2.2 自顶向下红黑树
12.2.3 自顶向下删除
12.3 确定性跳跃表
12.4 aa-树
12.5 treap树
12.6 k-d树
12.7 配对堆
总结
练习
参考文献
索引
· · · · · · ()

原文摘录 · · · · · · ( 全部 )

  • 数据抽象类型(ADT)是一些操作的集合。抽象数据类型是数学的抽象;在ADT的定义中根本没有涉及如何实现操作的集合。这可以看成模块化设计的扩充。 (查看原文)
    hao 2赞 2013年06月01日 16:49:57
    —— 引自第64页
  • 对表的操作可以用数组来实现。但是需要对表的大小的最大值进行估计,通常需要估计得大一些,会浪费大量的空间。这是严重的局限,特别是存在许多未知大小的表的情况下。所以简单数组一般不用来实现表这种结构。 (查看原文)
    hao 2赞 2013年06月01日 16:49:57
    —— 引自第64页

> 全部原文摘录

丛书信息 · · · · · ·

计算机科学丛书(共654册), 这套丛书还有 《数据仓库》《高性能嵌入式计算》《计算复杂性》《微控制器》《计算机系统》 等 。

喜欢读"数据结构与算法分析"的人也喜欢的电子书 · · · · · ·

支持 Web、iPhone、iPad、Android 阅读器
我来说两句

短评 · · · · · · ( 全部 468 条 )

我要写书评

数据结构与算法分析的书评 · · · · · · ( 全部 51 条 )

夜的旅者 2009年09月12日 22:02:22

评论数据结构与算法分析:C语言描述(原书第2版)

现在的程序员总是用着别人封装好的函数、类、库、API,满满的,我们就会觉得编程不过是这么回事,搭积木而已,别人都把材料提供好了,至于材料是怎么做的,不用理会。 真的是这样吗?说数据结构和算法没用的人,那是因为他用不到。为什么用不到?他的层次决定了他不会接触到编... ()
老C 2012年08月22日 21:27:57

很实用的算法书籍

这本书买了很多年,搬了这么多次工位,一直在办公室常备的书(虽然已经很少翻看). 里面使用的代码,不是所谓的伪代码,而是正经可以运行的C代码,所以新人如果能照着做一遍下来,收获应该不小. 我的一个朋友,很多年前也是读这本书写了一些笔记: http://www.luocong.com/dsaanotes/ ... ()
binary 2011年09月14日 21:42:16

翻译的不行

在学校图书馆借了这本书, 粗略看了一些,发现感觉很多句子不通顺。。。 感觉像《 c primer plus》那本书的翻译风格才是好的。 希望翻译者以后在翻译相关书籍时注意语言的通顺和典雅,不要 太生硬。 ()
Earthson 2012年12月26日 02:00:26

兼顾入门,广度和深度

这种程度的书确实很少能见到了。 它不在简单的地方无谓的浪费笔墨,恰到好处的把初学者带入算法和数据结构的世界。 它基本上涉及了数据结构基础的"方方面面"。很难想象这书的厚度,居然能讲这么多内容(你看看算法导论有多厚就知道我在说什么了)。 它在内容上并不乏深度... ()
breaker 2012年07月27日 19:42:46 人民邮电出版社2007版

优选 C 语言描述的算法分析 + 不用心的翻译

本书作者 Mark Allen Weiss 还写过 C 语言描述 和 Java 语言描述 版本的数据结构和算法分析教程。 另外,图灵出版社的同系列还有 Michael McMillan 写的 C# 语言描述 版本的算法书。 C++ 熟练者可忽略讲述 C++ 特性的第1章,如果把这些关于 C++ 特性的篇幅去掉,本书会精... ()
Johnny 2011年01月17日 23:11:52 机械工业出版社2009版

最好的数据结构与算法分析入门教程

因为最近需要复习数据结构与算法,所以网上搜索了下这方面的经典书籍。这本书的C语言版本高居榜首,获得一致好评,正好该书又有Java语言的版本,就买来拜读一下。前后大概花了1个月的时间将该书看了两遍,书中的主要数据结构都敲代码实现了一遍,现在算是将以前的数据结构课程... ()
尼摩 2006年12月26日 16:50:40

叹为观止的算法基础经典

开篇第一章引论的第一节提出一个问题: "设有一组N个数而要确定其中第K个最大者" 并给出两种解法 全排序后返回K位置上的元素。平均复杂度O(NLogN) 再建立一个临时数组,从N中读取K个数,全排序,然后依次读入其余N - K个数进来和第K名比较,大于K的值则插入到合适位置... ()
Jackon 2010年10月01日 10:36:47

变态的数学分析,变态的习题

断断续续看了两个月,没有完全看完。 所有的算法都能看懂,而且可以编程实现,但还是不会做习题。 离散数学的功底不行,先看看离散数学再看这本书。 ()
加菲猫 2008年09月18日 22:25:03

这本书真是非常好!

这本书真是非常好!个人感觉很适合给初学者入门看,里面的分析数学公式恰到好处,没有算法导论的令人望而生畏,也没有国内图书的草草了事,既学习了数据结构又有刚刚好的算法分析,很容易使人产生共鸣。 给我印象深刻的就是快速排序那一段,真是精彩! ()
zyx 2020年12月18日 23:42:20 机械工业出版社2016版

一本英文版凑合,中文版垃圾的书

感觉大部分写书评或者推荐本书的人可能都没有看完这本书的原著,写的可能有失偏颇。 我因为这本书的中文翻译实在是难以阅读,找来了原著来读。经过一段时间的努力,至少可以说看完这本书的大概内容,也算有资格能评价这本书了。 这本书的好处在于数据结构知识不仅全面而且深入... ()

> 更多书评 51篇

论坛 · · · · · ·

想问下,这本书真的适合初学者吗? 来自庭疏 2 回应 2024年02月25日 11:56:09
douban c语言QQ群:31609260 来自sd 2021年05月20日 18:42:04
p114哈希表的初始化函数有问题? 来自eastcloud 2018年09月05日 23:21:24
P124页的Rehash函数实现有内存泄露 来自knightley 2018年08月20日 11:03:57
有谁知道这个书的代码在哪里有? 来自cat&code 2018年07月17日 13:28:56

> 浏览更多话题

以下书单推荐 · · · · · · ( 全部 )

谁读这本书? · · · · · ·


1月3日 想读


阿什蘭公園
2025年12月30日 想读


氓女流
2025年12月29日 想读



2025年12月27日 想读


> 1217人在读

> 2171人读过

> 9169人想读

二手市场 · · · · · ·

订阅关于数据结构与算法分析的评论:
feed: rss 2.0

AltStyle によって変換されたページ (->オリジナル) /