- 在线时间
- 0 小时
- 最后登录
- 2013-7-18
- 注册时间
- 2013-7-18
- 听众数
- 0
- 收听数
- 0
- 能力
- 0 分
- 体力
- 1 点
- 威望
- 0 点
- 阅读权限
- 10
- 积分
- 0
- 相册
- 0
- 日志
- 0
- 记录
- 0
- 帖子
- 0
- 主题
- 0
- 精华
- 0
- 分享
- 0
- 好友
- 1
升级   0% 该用户从未签到 - 自我介绍
- 技术圈里的非技术人
 |
本帖最后由 zuoninger 于 2013-7-18 09:39 编辑 " { g, p$ M: W$ n( o& {+ Q9 S7 H8 ? @
. J4 |. U+ {4 h
世界顶级程序设计高手的经验总结
3 s2 ]9 o. A# }5 }" z% \【ACM-ICPC全球总冠军】巫泽俊主译 ' v% v% l8 E' b
日本ACM-ICPC参赛者人手一册
2 o; m: J( @1 v* \# }& v9 u( j" s# T" a! k( d" T$ P
1 t# q0 u1 _/ k" P: P: T7 Z
& H1 f j0 O8 p! F9 g9 d- I4 k) ^
先来介绍一下我们这本应该人手一册的《挑战程序设计竞赛》(第2版)译者,这颗闪耀在编程竞赛中的明星巫泽俊,就在2011年的5月30下午2时,他获得了第35届ACM国际大学生程序设计竞赛全球总决赛冠军,媒体称他为“世界最聪明的人”。(见下图)
, U/ i% h) M: y5 s3 _8 A( M; N8 M0 E8 O2 I
+ g) b2 n. U" a) J# @7 P0 e# m6 y) i3 i H6 T5 o0 J
![]()
7 h# v, x# \1 x$ Q; E7 C/ e) z# s' f8 v' Q2 U" J; `$ ?& m- ?" E6 p: L7 }. W8 M
( m% c. u" c. D, H5 z
巫泽俊平时训练的实验室
) S l+ a: u: g# n' V
k. P+ h+ Y, J0 D+ C8 ^* A: E
" s% z! ?% Q* f2 u ! L- n* X9 w( e. q
巫泽俊
$ X4 E: v- Y' u, P9 h. I' }9 f% L
/ s( m4 u d: v- d让我们看顶级ACM-ICPC总冠军是如何来介绍这本译作的!3 N& S0 I& @* D
- S+ t! O& g1 s/ l程序设计竞赛因其涉及的知识面广,比赛形式激烈有趣,吸引了越来越多的学生参与其中。参赛者不但可以从中锻炼算法设计能力,还能够提高代码编写能力。其中的佼佼者也受到了越来越多国际知名公司的重视和欢迎。 本书的几位作者是世界公认的顶尖选手,在竞赛和学术领域都取得了令人瞩目的成就。他们结合自己的专业知识和比赛经验,将自己的心得和技巧集结成书。
' w7 Z" n( @- i! ?- c. a# `9 s% }/ K, P' d
全书将不同的算法和例题按专题编排成小节,再将不同的小节由易到难分成四章,这样即便是初出茅庐的新手也不会有太大的阅读障碍。书中涵盖了在程序设计竞赛中会用到的大多数算法和技巧,并在附录中补充了书中未介绍但也比较有用的算法。在题材的安排上,作者取舍得当,主次分明,循序渐进,不以华而不实的奇技淫巧误导读者,又具有一定深度,相信即便是经验丰富的老将同样能从书中有所斩获。本书在结合例题进行讲解时,不是简单地堆砌问题和代码,而是注重引导读者更好地理解和运用算法来分析解决问题。对于正在学习数据结构与算法的读者而言,把它作为一本练习和拓展的参考书也是很好的选择。
; s- [1 M2 N- ^. w
) A. i* @, ~1 {本书在日本广受好评,还先后在台湾地区和韩国出版。近年来程序设计竞赛在亚洲发展很快,在中国大陆也出版了不少相关书籍,但鲜见高质量的佳作。所以,在读到此书时,我们非常惊喜,迫切希望中国大陆也能引进这样的好书。2012年初,我们通过作者的推特了解到了本书第二版的出版,一些前辈们踊跃翻译计算机专业书籍的经历也鼓舞了我们,让我们萌生了亲自翻译此书的念头并联系了图灵教育。非常幸运的是,图灵教育也正考虑引进此书,于是有了今天呈现在各位读者面前的简体中文版。3 x" [% Q7 A7 M" w, j' r" W( E
' v( Q G4 ~# k, R
在翻译上,我们力求做到既尊重国内选手的习惯,又符合计算机专业的表述。在修正原书中的一些笔误的同时,加入了一些译者注,以方便国内读者理解。但由于译者水平有限,不足之处在所难免,还望读者多多包涵,并不吝提出意见和建议。
5 z/ ^& G7 v. z, [7 D1 D9 t0 J- ~$ X
7 w2 @) J; v; t e在翻译过程中,秋叶拓哉、岩田阳一和北川宜稔三位作者耐心地对我们的一些疑问和笔误给予了一一解答和确认。浙江大学的陈越、王灿和翁恺三位老师不但将我们领进了“快乐”竞赛的大门,还拨冗审阅了译稿并提出了宝贵的意见。网上不少同好也对本书的出版给予了关切和支持。在此谨对他们表示感谢。
' q, z8 o- d5 N. y: M/ ~8 E$ X a8 F0 L
从目录中了解这本书是否符合你的需求
0 R/ K% T* T8 V4 X* }; W
) E7 B$ R E6 Z9 H
2 H- t. x# }+ H5 K0 |第1章 蓄势待发——准备篇' N; x! [4 X9 `$ T/ j) l( A
1.1 何谓程序设计竞赛 y- r% Y: I! y! M* A) h) j" y
1.2 最负盛名的程序设计竞赛
8 X$ U# `) @- Y4 }1.2.1 世界规模的大赛——Google Code Jam(GCJ)/ k# Q3 g' \& ^' [- j7 j% ?
1.2.2 向高排名看齐!——TopCoder
2 t4 e, O$ H! e5 H! x! U1 z3 t3 q1.2.3 历史最悠久的竞赛—— ACM-ICPC0 ?3 `# R* \$ i' G( h2 t
1.2.4 面向中学生的信息学奥林匹克竞赛——JOI-IOI. g6 X$ {% Y& i3 O6 {, I
1.2.5 通过网络自动评测——Online Judge(OJ)
6 m- V8 Q! t8 P# V0 i1.3 本书的使用方法
4 |: R. f, H O2 {6 F1.3.1 本书所涉及的内容( _ X" ~8 Z$ _* Z2 C7 Q+ y
1.3.2 所用的编程语言
; Q# g7 c% Q( }, \' I: \1.3.3 题目描述的处理# K: q) ~& q" r9 O* N& {
1.3.4 程序结构% ` L) [) ?' M* V( F' O( t) m$ p/ X$ A
1.3.5 练习题& P! s5 p M* D2 p& I
1.3.6 读透本书后更上一层楼的练习方法" ~4 ?+ Y* H6 S6 k8 D& ~- P# I. Z
1.4 如何提交解答6 B& t% U. I6 F) V* W" H! x
1.4.1 POJ的提交方法
0 K1 p" _$ I7 A) \0 \ L9 K1.4.2 GCJ的提交方法; M5 b2 Q9 `- }0 j* b, Z* M9 @
1.5 以高效的算法为目标
6 O$ C/ \' x3 n& s1.5.1 什么是复杂度
7 z6 Q: Q7 D9 o4 T" U$ S9 {4 r/ X9 a4 x1.5.2 关于运行时间2 {* K# F" s/ }, v% X! Y9 d# d- N4 s" Y
1.6 轻松热身
" ?) c5 ^) r+ D: I: q1.6.1 先从简单题开始$ X5 c+ a; v+ e$ k
1.6.2 POJ的题目Ants# I; _1 _ c% w# A
1.6.3 难度增加的抽签问题
1 {/ ^6 l0 L6 E5 z7 ?/ u阅读" x+ i# U$ d3 D8 p; ~+ b
第2章 初出茅庐——初级篇4 f4 m& h) J* S; f& X( f( y) ~+ k
2.1 最基础的“穷竭搜索”
) H r2 N0 I3 J, A$ a0 `' H' E/ l2.1.1 递归函数: m ?, P% ]3 p/ X( [
2.1.2 栈8 O( _' {1 A5 U& u3 L+ j1 e
2.1.3 队列+ J Z. _/ I- e, `
2.1.4 深度优先搜索8 ~( u' V9 |; P j$ S
2.1.5 宽度优先搜索 H: l2 y1 E; t* R- b' a5 S% M
2.1.6 特殊状态的枚举( a/ C7 m' p' n7 q, x
2.1.7 剪枝
) ^1 ?( l9 {2 ?+ @2.2 一往直前!贪心法% {: M' l" v1 b- c1 ^% b# W& u
2.2.1 硬币问题
* `; ]4 |! o6 g4 ?3 c2.2.2 区间问题8 y2 \2 Y1 {. S6 B
2.2.3 字典序最小问题
! Q# U/ M1 T9 i$ `6 S) O% h2.2.4 其他例题1 G$ v( P# H/ [+ U/ A
2.3 记录结果再利用的“动态规划”
! ?% U3 f( J7 q6 t. V2.3.1 记忆化搜索与动态规划( f# A7 q9 Z" k5 N7 J+ s t* c2 P
2.3.2 进一步探讨递推关系3 Y8 X& X: R% r: N" V7 U9 r
2.3.3 有关计数问题的DP# V0 B4 Z6 F3 d2 m, R9 t
2.4 加工并存储数据的数据结构% M/ {% o; u' E- l4 `# x
2.4.1 树和二叉树
! I' A- V# M) J7 d: s/ x2.4.2 优先队列和堆/ r1 V9 I) b: D3 |9 \: I
2.4.3 二叉搜索树* B! O( Y% ~1 E- j) _
2.4.4 并查集 n2 e% v- ~. t8 p( g9 p
2.5 它们其实都是“图”
6 l" T! k5 `7 c2.5.1 图是什么) s; L" R8 J* J4 I9 y
2.5.2 图的表示
* x# L% Q+ K& s- {& V# h2.5.3 图的搜索
; x3 ?7 I/ U$ N2 r6 \, @* y2.5.4 最短路问题' d. n: Y- g1 A
2.5.5 最小生成树$ a; b3 v" S! Z
2.5.6 应用问题
P E; ]$ }+ Z" ?" q* t+ g& F2.6 数学问题的解题窍门% k- J, a* o1 R1 T" p5 i& i
2.6.1 辗转相除法/ d3 i9 w1 C6 @ M3 C- V
2.6.2 有关素数的基础算法
! x% q. j) I2 D8 ]5 J* a2 E8 E2.6.3 模运算' `# G- C$ y% g/ c" l
2.6.4 快速幂运算6 {$ }/ K. |0 H1 \9 q1 S
2.7 一起来挑战GCJ的题目(1)) c* V* r$ j \0 Q' \$ D% @1 o
2.7.1 Minimum Scalar Product: W% N2 i& D( `( H! j `
2.7.2 Crazy Rows, [+ K, n7 q) f* E
2.7.3 Bribe the Prisoners' f, O& \9 U- M4 k4 z2 p- N
2.7.4 Millionaire9 z/ M+ c1 Q& G, b" s2 Q' H
阅读
! M1 S7 M% {9 w) F$ V: d" L第3章 出类拔萃——中级篇
+ B, V# [$ \/ B2 l" y0 l3 Q& }3.1 不光是查找值!“二分搜索”5 D! R' z$ b! l, e* j
3.1.1 从有序数组中查找某个值
3 s, |( ^7 I$ N* E' E+ E3.1.2 假定一个解并判断是否可行; j8 ]$ D# P& F' W+ I
3.1.3 最大化最小值
1 }+ f# `( D8 f0 |% U) W! M3.1.4 最大化平均值
! t& L: n2 R4 P* M- I' l) L/ O1 Z3.2 常用技巧精选(一)
, J6 b$ F8 y9 r( O9 d3.2.1 尺取法4 W3 n+ j" ]5 K# h% ?
3.2.2 反转(开关问题); h, p9 o/ C7 W0 z' Q
3.2.3 弹性碰撞7 {9 g% }0 X7 x$ a4 N0 \
3.2.4 折半枚举(双向搜索)7 t- J, T6 S5 j* S; n* k
3.2.5 坐标离散化7 A$ `6 d4 Z6 m
3.3 活用各种数据结构
. _2 l3 x: R- u3.3.1 线段树* j+ G# s" }- R* p9 M
3.3.2 Binary Indexed Tree) q. c' z$ B3 ^; q1 j, i1 q
3.3.3 分桶法和平方分割
4 q& g* F, X+ w" C3 j3.4 熟练掌握动态规划
! h! g$ b9 p# d& }0 e+ B7 q1 p8 A3.4.1 状态压缩DP1 z, L# a" J' O; p: B2 [
3.4.2 矩阵的幂
2 F/ b$ B4 {2 y R; g1 [3.4.3 利用数据结构高效求解2 {, B" B& \' y0 R
3.5 借助水流解决问题的网络流
" o" I4 ^+ d! j2 B3.5.1 最大流3 ^. Q: d* u. l* [
3.5.2 最小割
" H4 h, e# _" H* N3.5.3 二分图匹配
! S9 I7 N( D. m: O* l3.5.4 一般图匹配 |2 y: ~5 k" N7 t
3.5.5 匹配、边覆盖、独立集和顶点覆盖
* i9 y- T. P( i0 C3.5.6 最小费用流
% v9 q! D j: |3 Z! }! b, ?+ T3.5.7 应用问题 w1 p/ D6 a0 S- b
3.6 与平面和空间打交道的计算几何* Q7 u/ k3 N5 ?
3.6.1 计算几何基础5 f# P( ]" I& h; u) Y4 f
3.6.2 极限情况
1 S+ T0 _ H- p/ U% P1 G, \& `3.6.3 平面扫描
3 q& X! ?2 j5 r$ @ m% N3.6.4 凸包
4 } d. D( f% B0 s3.6.5 数值积分4 [ y; S3 i* T+ l# j/ E
3.7 一起来挑战GCJ的题目(2)- _. p c. b6 X+ V% D; y- h. _
3.7.1 Numbers$ }' m k( F5 ^2 @0 S* c# N
3.7.2 No Cheating
8 @5 u/ i" b! k7 s+ x3.7.3 Stock Charts8 ^7 n E8 R& N( k
3.7.4 Watering Plants5 O$ } R9 `/ j5 _6 j% P
3.7.5 Number Sets7 q8 z1 D2 L, M. J8 m
3.7.6 Wi-fi Towers
+ e5 E( T$ O* {" j p6 ~第4章 登峰造极——高级篇8 X K- q1 J/ `1 f# W6 ?9 }6 {3 O
4.1 更加复杂的数学问题' E# T" L, e& L9 w
4.1.1 矩阵
+ f" S( ?' o/ O4 Y w- U- c4.1.2 模运算的世界
) B* U0 l' ]0 ^3 C- Y& s. N4.1.3 计数/ }3 u6 K7 z7 \5 Z0 `( z
4.1.4 具有对称性的计数0 Y( @8 ]4 l# K4 e, e
4.2 找出游戏的必胜策略" ]. Y/ \7 p% \" O3 a
4.2.1 游戏与必胜策略' b% j" Q* U9 T0 Q: N" b
4.2.2 Nim
( a8 r! I9 f# Q% l8 w8 k; u2 J6 ?4.2.3 Grundy数
( ?! B- l! Y1 H9 n% w7 f$ Z4.3 成为图论大师之路, _% g. l% ^2 @; ^
4.3.1 强连通分量分解
5 l! q3 `9 o/ A* n. V4.3.2 2-SAT
2 o0 c9 G* M5 x% ~, a4.3.3 LCA
/ f' X' c; D& I5 N8 J; n9 P$ c4.4 常用技巧精选(二)
: C- M0 ]/ q8 B4 t, v4.4.1 栈的运用# B$ S/ y$ N1 s3 W' v
4.4.2 双端队列的运用( V1 ~: t/ G# Y
4.4.3 倍增法
+ g! i y) S8 ^( K4.5 开动脑筋智慧搜索% ^' S( R! l& v
4.5.1 剪枝
* {# O! ^ k0 n# {" @* q& M4.5.2 A*与IDA*
& \6 g# j' ]+ c4 P" C, V* g4.6 划分、解决、合并:分治法
1 h4 L1 o9 ^7 V# Y/ A4.6.1 数列上的分治法& s# [0 ?( U6 }0 ~5 U+ X
4.6.2 树上的分治法' L5 {- V& G2 g' z
4.6.3 平面上的分治法6 |% W' S; M u4 x) h
4.7 华丽地处理字符串
( t# G, C. p, Q6 I2 R4 a4.7.1 字符串上的动态规划算法
' ~! i3 E& |: c4.7.2 字符串匹配
: I- J4 r2 o5 k+ b. ^4.7.3 后缀数组
9 I1 i, q0 I! T4.8 一起来挑战GCJ的题目(3) u3 k+ F& V2 A% L
4.8.1 Mine Layer
6 ~9 u) q2 P7 u+ ~4 U" z% O4.8.2 Year of More Code Jam
% O' R" `& |7 A7 ?* n. f+ d& l4.8.3 Football Team+ j) O2 @7 E& t% C0 ~
4.8.4 Endless Knight
1 h, g: p1 b3 t+ g5 X9 h! |4.8.5 The Year of Code Jam
8 A$ z3 a$ y% p7 _ I Q
+ B1 c t/ H( Y稍后会上传迷你书!!! |
zan
|