QQ登录

只需要一步,快速开始

 注册地址  找回密码
查看: 6095|回复: 8
打印 上一主题 下一主题

ACM-ICPC参赛者人手一册讲解算法的书,你准备了没?

[复制链接]
字体大小: 正常 放大
zuoninger        

0

主题

0

听众

0

积分

升级  0%

该用户从未签到

自我介绍
技术圈里的非技术人
跳转到指定楼层
1#
发表于 2013-7-18 09:37 |只看该作者 |倒序浏览
|招呼Ta 关注Ta
本帖最后由 zuoninger 于 2013-7-18 09:39 编辑
5 c& A. o) r5 v/ G+ m" y" f
: x1 `: b' q" U- t世界顶级程序设计高手的经验总结
9 n! `/ i- P! X# U* d$ |8 k【ACM-ICPC全球总冠军】巫泽俊主译 ' N8 R3 I1 j1 D6 K
日本ACM-ICPC参赛者人手一册

: Y3 A+ O* I/ a2 e5 E, ^3 a- a
2 m5 m* [6 a; p: O% x, Q& y7 u/ e$ c' f( y- W' H2 U2 ?

1 ^. V) K. o7 f7 ]2 L- r先来介绍一下我们这本应该人手一册的《挑战程序设计竞赛》(第2版)译者,这颗闪耀在编程竞赛中的明星巫泽俊,就在2011年的5月30下午2时,他获得了第35届ACM国际大学生程序设计竞赛全球总决赛冠军,媒体称他为“世界最聪明的人”。(见下图)
7 K7 k2 l1 F9 R4 g: G# \7 r- Y- I1 T) u$ m- u
: d3 y& K. z/ h: x( L2 w6 Q- [

& k  G8 A- ?- X$ @; ?! V0 }' j* n- f  K8 @+ c1 C9 d* f' H
% A. C1 T! e% Q$ u$ y- c* j
巫泽俊平时训练的实验室+ T+ Z; m% A: \

+ m) H5 R, s3 @5 N
, B* B( p- ]' ]+ L# F$ B
' J0 v5 @. k) ^& i4 z巫泽俊
! V( S1 P+ A: F3 a& _" i- J6 g7 |' b) G
让我们看顶级ACM-ICPC总冠军是如何来介绍这本译作的!
- V+ y. L, ]. l  i; p7 M+ M6 g/ ]- Z
程序设计竞赛因其涉及的知识面广,比赛形式激烈有趣,吸引了越来越多的学生参与其中。参赛者不但可以从中锻炼算法设计能力,还能够提高代码编写能力。其中的佼佼者也受到了越来越多国际知名公司的重视和欢迎。 本书的几位作者是世界公认的顶尖选手,在竞赛和学术领域都取得了令人瞩目的成就。他们结合自己的专业知识和比赛经验,将自己的心得和技巧集结成书。4 }) M$ K7 O+ l# x- m4 ?3 j8 |

! i, u3 ^% F' X  T. T) p& r全书将不同的算法和例题按专题编排成小节,再将不同的小节由易到难分成四章,这样即便是初出茅庐的新手也不会有太大的阅读障碍。书中涵盖了在程序设计竞赛中会用到的大多数算法和技巧,并在附录中补充了书中未介绍但也比较有用的算法。在题材的安排上,作者取舍得当,主次分明,循序渐进,不以华而不实的奇技淫巧误导读者,又具有一定深度,相信即便是经验丰富的老将同样能从书中有所斩获。本书在结合例题进行讲解时,不是简单地堆砌问题和代码,而是注重引导读者更好地理解和运用算法来分析解决问题。对于正在学习数据结构与算法的读者而言,把它作为一本练习和拓展的参考书也是很好的选择。* }( N/ V; y+ _( T- e

* g& F! m+ L/ I本书在日本广受好评,还先后在台湾地区和韩国出版。近年来程序设计竞赛在亚洲发展很快,在中国大陆也出版了不少相关书籍,但鲜见高质量的佳作。所以,在读到此书时,我们非常惊喜,迫切希望中国大陆也能引进这样的好书。2012年初,我们通过作者的推特了解到了本书第二版的出版,一些前辈们踊跃翻译计算机专业书籍的经历也鼓舞了我们,让我们萌生了亲自翻译此书的念头并联系了图灵教育。非常幸运的是,图灵教育也正考虑引进此书,于是有了今天呈现在各位读者面前的简体中文版。
4 H2 |/ B: M/ P! A: A6 r  _, d
4 \/ u( i+ O2 u2 M4 d7 D. u在翻译上,我们力求做到既尊重国内选手的习惯,又符合计算机专业的表述。在修正原书中的一些笔误的同时,加入了一些译者注,以方便国内读者理解。但由于译者水平有限,不足之处在所难免,还望读者多多包涵,并不吝提出意见和建议。- K) V  w" c( M/ s
& a" z; s  `8 r7 C0 l0 W/ X% w
在翻译过程中,秋叶拓哉、岩田阳一和北川宜稔三位作者耐心地对我们的一些疑问和笔误给予了一一解答和确认。浙江大学的陈越、王灿和翁恺三位老师不但将我们领进了“快乐”竞赛的大门,还拨冗审阅了译稿并提出了宝贵的意见。网上不少同好也对本书的出版给予了关切和支持。在此谨对他们表示感谢。) h3 C' x3 u# K

6 _) G7 A" E) j1 H' L# j从目录中了解这本书是否符合你的需求9 J5 {; D, n) M" W, F
! i( z0 e4 l" D
' T4 y0 y1 R  v
第1章 蓄势待发——准备篇
/ f% I' ?: h% g1 G' q1.1  何谓程序设计竞赛) G- t6 b- j  J( ^7 U; R& M
1.2  最负盛名的程序设计竞赛
! K& R) d# H, c; X9 ^/ F8 o1.2.1  世界规模的大赛——Google Code Jam(GCJ)
, x( j7 J* x  Y+ [$ @' u1.2.2  向高排名看齐!——TopCoder
6 x( v8 s  M, g# ^% A& V1.2.3  历史最悠久的竞赛—— ACM-ICPC
! f: L( m  H9 Y# K5 Y1.2.4  面向中学生的信息学奥林匹克竞赛——JOI-IOI( y3 K" J! T& i) h2 A! K
1.2.5  通过网络自动评测——Online Judge(OJ)+ f) m  v2 r2 x6 s
1.3  本书的使用方法
- d- s3 e2 {) _: [7 h1.3.1  本书所涉及的内容1 q' v- p3 _# G* T( s2 K4 M
1.3.2  所用的编程语言( w: y  X, R# u, J! {
1.3.3  题目描述的处理/ i+ A+ ]0 }" @; @5 b( ^) k0 y0 T
1.3.4  程序结构& L) i7 @1 t$ ?0 b. w
1.3.5  练习题
' ~( d) W' M0 l; L. ]7 ^# p1.3.6  读透本书后更上一层楼的练习方法
5 w5 E  k, D" d$ y  M2 u) l1.4  如何提交解答" F3 X: m. ^& F: I8 Y
1.4.1  POJ的提交方法; W# c% [- E. R: N0 w
1.4.2  GCJ的提交方法6 q( G2 J4 n% u: Y
1.5  以高效的算法为目标' [. j0 @# T( O5 B- M" |
1.5.1  什么是复杂度
1 E- J, V" D; G+ t7 _1 o% p0 b1.5.2  关于运行时间: W0 s, I( K! ]& s2 J) s- \
1.6  轻松热身' i5 ^9 a0 R8 w% I- ~
1.6.1  先从简单题开始
1 Z9 Q3 M) X4 U' k# a% ^1.6.2  POJ的题目Ants
1 s! i' c% R* n  S1.6.3  难度增加的抽签问题
" b& }& C( Z5 T阅读
, o; D) F2 ]# C第2章 初出茅庐——初级篇
$ S3 X( ?# j: D# ^% D1 ~9 p$ y2.1  最基础的“穷竭搜索”1 N- t5 g9 m7 Q5 P9 f
2.1.1  递归函数+ ^; X4 \& Z2 {% D2 T: t2 x6 T
2.1.2  栈
8 R! k+ a" o: Z3 Z; y6 H2.1.3  队列+ R9 n4 J, \" Q2 t  w
2.1.4  深度优先搜索4 _0 y, p  [0 S9 \6 }
2.1.5  宽度优先搜索' Z3 L6 k6 u8 }; S/ {
2.1.6  特殊状态的枚举
; k  M8 F5 h" G0 x1 I, W. _- G2.1.7  剪枝
" c& \# t% C' e3 L  T2.2  一往直前!贪心法8 G# T3 U# [" Z& B# u
2.2.1  硬币问题
- I& r; X5 R6 e2.2.2  区间问题
( Z( j1 J* o$ z2.2.3  字典序最小问题
. Q+ B1 T/ i- ]" L1 l/ z9 j' J2.2.4  其他例题
# ?7 ]8 ]  a$ T2.3  记录结果再利用的“动态规划”
5 I$ ]# C& u' X3 V! u2.3.1  记忆化搜索与动态规划
, y6 \3 J3 R9 k& @2.3.2  进一步探讨递推关系! R- h$ [: ~/ |
2.3.3  有关计数问题的DP( ^( s! s* Q) U
2.4  加工并存储数据的数据结构5 m/ I1 Y+ h/ j$ j: u
2.4.1  树和二叉树
6 v, V6 w6 M! O) n' Z2.4.2  优先队列和堆  F- p: I) `! l% Z  X9 {
2.4.3  二叉搜索树' y2 L# s# m) n5 H
2.4.4  并查集
6 D: t/ |# V& c' s6 ?2.5  它们其实都是“图”
, b; y7 P+ i8 r; b2.5.1  图是什么2 y7 G6 `# W* [. B; [4 p0 [$ Y  o
2.5.2  图的表示6 ~) y! q8 @/ q9 U6 A
2.5.3  图的搜索' h4 o: R7 e# Y6 @5 ~% k) W+ ~
2.5.4  最短路问题( J6 v9 e& y; h5 @2 h
2.5.5  最小生成树
  h% k- Z( n5 Q+ s2.5.6  应用问题7 q  |6 F# Z0 D" d+ A
2.6  数学问题的解题窍门/ y6 h! {& [, P- Q' S& r/ H* {8 g+ z
2.6.1  辗转相除法
3 l1 G% H- s% {; R# R! V2.6.2  有关素数的基础算法  u/ T$ z8 t4 V1 c1 @% Q  ^5 |
2.6.3  模运算
6 S5 W+ {; u5 L% B0 H3 T7 }# X2.6.4  快速幂运算
: Q# O. z( T' C2.7  一起来挑战GCJ的题目(1)' k5 v5 S# ]  G3 R$ `' c' [
2.7.1  Minimum Scalar Product  N( z2 l2 e1 X
2.7.2  Crazy Rows
+ `, A, G& E3 O2 P2.7.3  Bribe the Prisoners7 I$ ]+ U( p# ]# p/ ~9 a
2.7.4  Millionaire: w6 ]/ @2 d( q3 {0 t3 F/ K
阅读
5 p+ [/ b8 `8 q+ p第3章 出类拔萃——中级篇! Y. }  R% d) \5 C9 z& ]
3.1  不光是查找值!“二分搜索”
! P/ `# A" }8 }; a3 l/ u5 U% q3.1.1  从有序数组中查找某个值
# o2 f; m/ Z7 r% J  }3.1.2  假定一个解并判断是否可行' I" G! [- i: J
3.1.3  最大化最小值0 `. L0 e6 ^* A; s0 {
3.1.4  最大化平均值
$ L  R$ T( l0 p: ]3 l3.2  常用技巧精选(一)
$ g6 \) P: f. C0 ], {  K1 ~: x3.2.1  尺取法" {8 Z( e. v! D
3.2.2  反转(开关问题)
9 W5 @8 P9 ~3 o3.2.3  弹性碰撞
# z" ?% U* U: k# [1 c  B8 T) S! G3.2.4  折半枚举(双向搜索)6 ?, @9 y( A) }9 E9 E1 R% m8 O3 v
3.2.5  坐标离散化
* H1 B* x! M+ U1 l( {( w3.3  活用各种数据结构
/ p! J1 ~8 }  ^! [+ b, f3.3.1  线段树
. M3 t4 x( g$ g6 q+ P% F# t7 [: c3.3.2  Binary Indexed Tree
3 P* ~& k1 z' A: x! g! M8 s3.3.3  分桶法和平方分割
0 V' Q4 N# r- i" m( {3.4  熟练掌握动态规划0 q0 _% Q- C) U# B. V
3.4.1  状态压缩DP0 w0 l/ l; [; ], x
3.4.2  矩阵的幂
" |5 u% V; e+ W+ e" T3.4.3  利用数据结构高效求解
. w& _" H; ]: t+ |5 e8 g$ s3.5  借助水流解决问题的网络流
3 Q! D1 l6 K" w1 l8 X) y5 g+ l3.5.1  最大流. R# j; L( G! k1 \
3.5.2  最小割
; x: C4 s% ?  u( q3.5.3  二分图匹配
% ~# Z$ i! ^* X' u( j6 ^3.5.4  一般图匹配
3 K9 }. ]1 q- N5 r* d& q3.5.5  匹配、边覆盖、独立集和顶点覆盖
; r$ j( v4 X0 ]  ~- S3.5.6  最小费用流
/ C( {8 |4 H3 Y( }$ }7 z3.5.7  应用问题" E) M% N- e# B) V( f+ D  Q: p
3.6  与平面和空间打交道的计算几何( z: r% s1 [# s% c3 Z) O$ w: p
3.6.1  计算几何基础  W/ x) @9 E+ t$ H" q' {; D& y+ c
3.6.2  极限情况$ C- G3 }/ L  F' `( x+ I$ ~# M
3.6.3  平面扫描
- T( H* X& i# E& X6 Z6 v3.6.4  凸包) C% e% S# D8 S3 s5 j% L. |
3.6.5  数值积分
0 Q7 i0 D% C! c9 [+ [7 s$ U3.7  一起来挑战GCJ的题目(2)
) d0 a% ~1 X1 L  k6 a% w3.7.1  Numbers- Z% C) x" H  P5 Q/ d) {
3.7.2  No Cheating
$ R) i6 i5 p0 G, q3.7.3  Stock Charts
* O' \* w4 s" [, O' ?0 T: D9 w) |/ ~3.7.4  Watering Plants
" Q. p/ C3 ?6 B0 E( U8 M3.7.5  Number Sets1 B1 k' }  Z' ~+ N' B( v
3.7.6  Wi-fi Towers) r: m0 G6 V% s! S8 x$ C8 x
第4章 登峰造极——高级篇
* s2 O& U9 G8 d2 Y4.1  更加复杂的数学问题
! Q  d' R, d! b+ j2 z* T4.1.1  矩阵! D/ Y* @; U! k+ K( n! P
4.1.2  模运算的世界9 t  I7 L9 t( y2 z9 s( n
4.1.3  计数
& |6 R  T* o1 f6 X9 y: }4.1.4  具有对称性的计数1 f+ e! X% j* ?; b
4.2  找出游戏的必胜策略
+ D! e' \0 O- K  s" B" W: t  o/ X4.2.1  游戏与必胜策略
  l# Q5 \3 }$ c8 t4.2.2  Nim! i: [* `- w7 Y. g) O$ d9 y4 |) k
4.2.3  Grundy数
: I4 E- \5 C! R2 a5 y/ Q7 J4.3  成为图论大师之路
0 B1 O  F# X5 E& u* Q2 c4 S4.3.1  强连通分量分解" |) B! m: b" N% j9 ~4 l
4.3.2  2-SAT& y  A- o( M4 n+ F* b$ e+ T/ N
4.3.3  LCA
& {8 U8 N8 g0 t' z' [4.4  常用技巧精选(二)" B4 g2 ?, e, h' n1 A
4.4.1  栈的运用) K+ _, O# E/ j
4.4.2  双端队列的运用3 y, v5 S5 d$ |0 q/ j' J
4.4.3  倍增法
( x3 O5 Z9 U: c. _; A' g, O/ o4.5  开动脑筋智慧搜索+ T! S) o6 |: \9 J% `) x5 w
4.5.1  剪枝3 r# l$ V; g5 i0 Y3 G$ W  [
4.5.2  A*与IDA*
* K1 h/ |1 i2 F5 k4.6  划分、解决、合并:分治法
! P# X. p. g# f7 p: ?. y4.6.1  数列上的分治法
2 B5 i0 x7 l* C5 e# z% i0 ]4.6.2  树上的分治法
  w6 r* H* `0 i( }: i. g* H4.6.3  平面上的分治法3 A  p0 S3 G1 o; M6 \" {, Z
4.7  华丽地处理字符串
0 p' v+ z; E5 X' }4 p, d6 z/ r4.7.1  字符串上的动态规划算法, a- t# z& j0 v3 R4 \5 h
4.7.2  字符串匹配' H: \  p" i4 _, G" P
4.7.3  后缀数组
4 W9 K! f; K  ]4.8  一起来挑战GCJ的题目(3)/ g. \; S3 l* z( M& {: d
4.8.1  Mine Layer
, ~9 Z6 R) g, f# q6 a* C0 O4.8.2  Year of More Code Jam
7 d& Z% k0 @% E# \: [1 I8 A4.8.3  Football Team
4 X7 ^. {: q& \4 f( \6 \; S7 b$ z4.8.4  Endless Knight4 p+ M' A7 {9 S/ d: T
4.8.5  The Year of Code Jam. {0 @' w5 e/ w4 Q& _* g1 V

/ x; n9 G* B  n8 J+ C- }- z" u7 G1 p稍后会上传迷你书!!!
zan
转播转播0 分享淘帖0 分享分享0 收藏收藏0 支持支持0 反对反对0 微信微信

2

主题

8

听众

226

积分

升级  63%

  • TA的每日心情
    无聊
    2014-11-17 15:36
  • 签到天数: 81 天

    [LV.6]常住居民II

    自我介绍
    我是一名工科生

    社区QQ达人

    回复

    使用道具 举报

    _kk        

    0

    主题

    6

    听众

    713

    积分

    升级  28.25%

  • TA的每日心情
    开心
    2014-9-2 23:30
  • 签到天数: 235 天

    [LV.7]常住居民III

    自我介绍
    hi

    群组2012HIMCM培训群组

    回复

    使用道具 举报

    Rain326        

    0

    主题

    5

    听众

    42

    积分

    升级  38.95%

  • TA的每日心情
    郁闷
    2014-12-2 16:24
  • 签到天数: 9 天

    [LV.3]偶尔看看II

    自我介绍
    我爱我师,我更爱真理!为数学疯狂!
    回复

    使用道具 举报

    kk_310        

    1

    主题

    5

    听众

    77

    积分

    升级  75.79%

  • TA的每日心情
    奋斗
    2014-2-7 09:36
  • 签到天数: 24 天

    [LV.4]偶尔看看III

    自我介绍
    热爱数学~
    回复

    使用道具 举报

    26

    主题

    30

    听众

    1400

    积分

    升级  40%

  • TA的每日心情
    开心
    2017-9-19 13:48
  • 签到天数: 138 天

    [LV.7]常住居民III

    新人进步奖

    群组数学建摸协会

    群组2013年数学建模国赛备

    群组河南工程学院数学建模

    群组第三届数模基础实训

    群组中国矿业大学数模培训

    回复

    使用道具 举报

    0

    主题

    6

    听众

    104

    积分

    升级  2%

  • TA的每日心情
    郁闷
    2013-12-3 23:14
  • 签到天数: 7 天

    [LV.3]偶尔看看II

    自我介绍
    shanghai university of finance and economics
    回复

    使用道具 举报

    0

    主题

    7

    听众

    51

    积分

    升级  48.42%

  • TA的每日心情
    奋斗
    2014-2-13 12:11
  • 签到天数: 27 天

    [LV.4]偶尔看看III

    群组第四届cumcm国赛实训

    群组2013年数学建模国赛备

    群组第四届数学中国美赛实

    群组2013年电工杯B题讨论群

    群组2013电工杯A题讨论群组

    回复

    使用道具 举报

    木__易        

    4

    主题

    10

    听众

    907

    积分

    升级  76.75%

  • TA的每日心情
    开心
    2017-1-7 12:01
  • 签到天数: 220 天

    [LV.7]常住居民III

    社区QQ达人

    群组2015年美赛冲刺

    群组哈尔滨工业大学建模团

    群组国赛讨论

    回复

    使用道具 举报

    您需要登录后才可以回帖 登录 | 注册地址

    qq
    收缩
    • 电话咨询

    • 04714969085
    fastpost

    关于我们| 联系我们| 诚征英才| 对外合作| 产品服务| QQ

    手机版|Archiver| |繁體中文 手机客户端  

    蒙公网安备 15010502000194号

    Powered by Discuz! X2.5   © 2001-2013 数学建模网-数学中国 ( 蒙ICP备14002410号-3 蒙BBS备-0002号 )     论坛法律顾问:王兆丰

    GMT+8, 2025-10-31 22:09 , Processed in 1.048457 second(s), 97 queries .

    回顶部