在线时间 463 小时 最后登录 2025-6-15 注册时间 2023-7-11 听众数 4 收听数 0 能力 0 分 体力 7342 点 威望 0 点 阅读权限 255 积分 2781 相册 0 日志 0 记录 0 帖子 1156 主题 1171 精华 0 分享 0 好友 1
该用户从未签到
书籍介绍' v# l8 g( D/ q& p" L
. p& O& g# k; j; m6 U; J1 Z6 O! O
这本教材源自于我在伊利诺伊大学香槟分校教授各种算法课程时所编写的一系列讲义。自1999年1月以来,我每年大约会教授一次这些课程。由于本科理论课程体系的变化,我在2016年对我的讲义进行了重大修订;本书则是我的修订笔记中关于最基础课程内容的一个子集,主要反映了我们新的必修大三级理论课程的算法内容。 t8 H U/ P, i2 y* }; x
8 z& U" W0 c( k$ o+ `+ }; a6 N 先决条件- g' V) d6 T2 m- f" D' t+ ]
' ?6 s- L ^5 p7 i 我在伊利诺伊大学教授的算法课程有两个重要的先决条件:& S* j# S' _/ M, y) l6 ]
1. **离散数学**课程/ l: j/ ^' P5 o
2. **基础数据结构**课程
4 ~ \7 E) N x. ~5 f . `1 K" r6 Z% S4 l8 N: ]
因此,这本教材可能不适合大多数学生作为入门书籍。
+ A6 x1 W2 w7 H4 X f$ P5 E
: O, @* @! k3 {" u% g4 i3 X 主要内容
( p/ X8 n! z+ z. m; R) D, \6 K/ `
& L2 K. A& e, @* \) P0 d 书中的内容涉及以下几个方面:. k2 C3 @( _; D5 m0 t6 C) c
# i& \- O1 Y5 f- d5 `- m
- **基本数据结构**:
! O8 k7 W1 R8 E8 L - 队列、映射/字典、排序映射/字典、优先队列
& m _) b- E0 j - 数组、链表(单向和双向、线性和循环)、二叉搜索树,至少一种形式的平衡二叉搜索树(如AVL树、红黑树、Treap、跳表或伸展树)、哈希表、二叉堆,以及最重要的,前面列表与此列表之间的区别。# T) f3 W: P2 `
0 R5 u' T1 B/ m$ ]+ E - **基本计算问题**:
; F* a3 K4 ?5 t - 基本算术、排序、搜索、枚举、树的遍历(先序、中序、后序、层序等)。
& b! D# i, N4 d, F6 D/ T% X& j$ w! @ ) ~$ _# ~8 w" ]9 H6 ~( P- Z/ n" m7 ^9 }
- **基本算法**:
- O! ?1 `4 _& z0 M/ O - 基本算法、顺序搜索、二分搜索、各种排序算法(选择排序、插入排序、归并排序、堆排序、快速排序、基数排序等)、在(至少二叉)树中的广度优先搜索和深度优先搜索,以及前面列表与此列表之间的区别。
" A7 L+ ^0 X0 Q- ^ W5 @4 G + `! l M0 X" K2 w4 u3 X
- **初步算法分析**:2 W; H; `$ ~$ f1 T
- 渐近符号(o, O, Θ, Ω, ω)、将循环转换为求和以及递归调用转换为递归关系、评估简单求和和递归关系。
: A7 K& X5 g1 o$ v7 S2 ^ | & i/ h3 F& q% h3 c
- **数学成熟度**:
& m/ z0 j8 S, {! F3 r7 P, q" L$ h* S - 对抽象、形式(尤其是递归)定义的熟悉程度,书写和理解数学论证的能力,识别和避免句法、语义和/或逻辑上的错误。6 E6 C( g! j q
% L) }3 W: @; R$ m( [& t( L+ O; k ### 书籍特点' f! j$ J- Z6 {# s2 k
9 `7 j C, H8 {! w 这本书在适当上下文中简要涵盖了一些先决条件材料,但更多的是作为提醒而不是全面的介绍。对于更深入的概述,我强烈推荐以下一些免费提供的参考资料。, M3 d. `0 F- c M* k
- T' P. @5 V& U1 V# L
本书旨在为希望深入研究算法及其理论的学生提供一个扎实的基础,然后他们可以在此基础上进一步学习更复杂和高级的算法概念。( r' s& o# z F5 N7 n
2 Y% F6 G( T+ B: k9 m 5 \' t# `7 x! O4 v M/ c
3 H/ |! x& t3 [3 D
zan