- 在线时间
- 2 小时
- 最后登录
- 2013-7-16
- 注册时间
- 2013-7-15
- 听众数
- 0
- 收听数
- 0
- 能力
- 0 分
- 体力
- 7 点
- 威望
- 0 点
- 阅读权限
- 20
- 积分
- 5
- 相册
- 0
- 日志
- 0
- 记录
- 0
- 帖子
- 3
- 主题
- 2
- 精华
- 0
- 分享
- 0
- 好友
- 11
升级   0% 该用户从未签到 - 自我介绍
- 爱数学,爱编程
 |
程序设计竞赛有着各种各样的形式,在此,我们来介绍其中最负盛名的几个。8 B* w7 ^4 _: n5 ~
/ O! W7 X( z9 c1 }' L" e世界规模的大赛——Google Code Jam(GCJ): M) Y# l$ t5 r% \0 H6 x
% ^) w/ H) C) |9 ]它是Google公司几乎每年都会举办的世界规模的程序设计竞赛,参赛者要在2~3小时内解决大约4道题。一旦从在线(Online)进行的几轮预选中胜出,就能够参加现场(Onsite)总决赛。该赛事的特点是,每道题都备有Small和Large两组输入数据。即便是难度系数较大的问题,只要输入规模足够小,依然可以简单地求解,这一形式深受广大参赛者的喜欢。另外,GCJ并不在服务器上自动执行程序,而是要求将源代码和本地执行的结果一同提交。
" g s I' G; b0 m8 o" d7 @: ^
! `9 b8 ~/ X) l2 c7 w6 A向高排名看齐!——TopCoder7 a/ h {% G6 S5 z' S+ \
" g! O) c5 D4 S1 H6 n
TopCoder公司是一家策划并举办程序设计竞赛的公司,它举办的比赛涉及多个领域。其中之一就是算法(Algorithm)比赛,该赛事大致每周都以SRM(Single Round Match)的形式举办一场,其具有以下特点。! o$ c) K H# P( s/ {0 v
" C- x- ^# j, Y(1) 在1小时15分钟的短时间内挑战3道题。- _- E4 ^ | t# `8 t# s6 J
* F( y+ j7 N, V& w0 d- w(2) 提交的结果在比赛结束前是不知道的,整个过程中稍有失误,就会变成0分。: M* ^( m. x, A7 \' h& k9 h
% [' }" |' k# A; w" o! G' G(3) 在编码阶段(coding phase)结束后,还有一个挑战阶段(challege phase)。该阶段可以查找别人代码中的漏洞。如果能够提供一组输入数据,使别人的程序返回错误的结果,就能得到额外的分数。
, C1 c* k0 @2 M, J. I3 g* v9 Z# r. T) @% {1 Q+ h8 M
其中第3条是该赛事独一无二的特点 ,也是阅读别人代码的好机会。TopCoder还有一个深受大家喜欢的等级分系统(rating system),它会依据SRM的结果给参赛选手排名。另外,TopCoder还会举办一年一度的TCO(TopCoder Open)公开赛。一旦从在线进行的几轮预选中胜出,就能够参加在拉斯维加斯 举办的总决赛。! `8 t. F: b( F) ], A
- w% H& c( @. D- l4 `历史最悠久的竞赛——ACM-ICPC4 W7 G0 s$ C$ m
" F, h: T4 y7 B* T# KACM-ICPC是由美国计算机协会(ACM)主办的、面向大学生的竞赛,也是历史最悠久的程序设计竞赛。这是一个三人一队的团队比赛,选手要在5个小时内解决大约10道题。因为比赛中三名选手共用一台电脑,题量又比其他赛事多,并且多是一些实现复杂的问题,所以团队配合显得异常重要。想要从日本参加该项赛事,首先要参加在线进行的国内预选赛,胜出后才能参加亚洲区域赛,取得前几名的好成绩后才能够参加世界总决赛。
' i$ q9 b! r# u. w2 {
7 U" F6 a& F+ w3 b0 `, n讲到ACM-ICPC,不得不提到我们的《挑战程序设计竞赛》(第2版)译者,这颗闪耀在编程竞赛中的明星巫泽俊,就在2011年的5月30下午2时,他获得了第35届ACM国际大学生程序设计竞赛全球总决赛冠军,媒体称他为“世界最聪明的人”。(见下图)
% v% C% x( w9 F
6 y- F$ b6 x, {5 i' n" v( t $ f; S5 f% B: y. P
8 Z* Y" n$ [( b' Q' J8 H7 G, O# M
![]()
7 W' x S/ q6 @/ b5 m' t+ F; `+ R5 M- s$ J* A/ O: P
巫泽俊平时训练的实验室
( X& U' K6 s% o# D% L2 X6 B/ _% R% t$ B" J
![]()
% E1 l& t+ r& T& C# }. p2 P$ Z4 W; T" E
巫泽俊
( G5 g3 p- Q+ A$ |/ Q* L# e4 r6 n$ B3 V" R# r9 y: F) ]; `) w7 Y
面向中学生的信息学奥林匹克竞赛——JOI-IOI9 t. X& k$ k8 j3 x
# t5 [; _- ^) Q1 f1 L5 X, n
信息学奥林匹克竞赛是学科奥林匹克竞赛的一种,是以初中生和高中生为参赛对象的程序设计竞赛。在日本,首先要参加日本信息学奥林匹克竞赛,取得优异成绩后,才能作为日本国家队选手参加国际信息学奥林匹克竞赛。 其他比赛都需要尽可能快地解决尽可能多的问题,而信息学奥林匹克竞赛只要在规定时间内求解问题即可,成绩与所用时间无关,但是它相对其他比赛而言,求解每道题所花的时间要长得多。虽然是面向中学生的比赛,每年所出问题的难度却是非常高的。
9 h' H( ?% \, F5 o6 V5 R4 W2 L8 }
3 y" h* g+ }2 k7 X% ]/ q, r9 N通过网络自动评测——Online Judge(OJ)
5 z4 Z1 W+ l. `0 w, L
" I2 y+ L/ u% L在互联网上,有一些被称为Online Judge的系统,它们能够自动评测以往程序设计竞赛中的题目。利用该系统就可以练习了。另外,其中一些Online Judge也会定期举办自己的比赛,不妨去参加一下。在此列举几个有名的Online Judge。6 m( B9 p8 Q) K; L: p
& s @$ g' U. K2 T% G, v
PKU Online Judge (POJ)—— 题库中有大量的题目。8 [: c; U5 @/ q
会津大学Online Judge(AOJ)—— 还包含日语题。8 q3 G. Z+ C) T6 [0 _6 r1 s2 ~
Sphere Online Judge(SPOJ)—— 允许使用各种各样的编程语言。
+ P& k& W# g1 B0 ?6 T4 U0 I& pSGU Online Contester—— 具有模拟参加历史比赛的虚拟赛功能。+ |: M- _/ J, M) Y7 \1 Z
UVa Online Judge—— 老字号Online Judge,经常举办比赛。) _( [. M/ I/ I+ p( [
Codecorces—— 与TopCoder一样定期举办比赛,又同其他网站一样不断维护历届题库。' d6 Q" i2 Q3 E4 B. o9 N; a
关于本书
2 w( o9 T @* X4 f5 j* Z- G! R; |; ^; }
0 y4 E7 ]: j3 j! W
; p6 y: U& U+ I% |. Q
《挑战程序设计竞赛(第2版)》分为准备篇、初级篇、中级篇与高级篇4章。作者结合自己丰富的参赛经验,对严格筛选的110 多道各类试题进行了由易及难的细致讲解,每章后附有习题。 通过本书不仅可以学到算法,更能学到其设计和运用的思想。- m( Q1 z& T* d8 L" j: M9 r/ J" u
: ]2 T/ ^. i$ j
只要是具有编程基础知识的读者,均适合阅读本书。书中的源代码均用C++实现,不过只用到了其基本功能,所以即便读者不熟悉C++也不影响阅读。/ e8 ]( j. x# v) l B7 B
5 h; z4 n n4 `- V4 b
本书的第一版被台湾和韩国引进,获得了一致的好评,让我们看看其他两版的封面风格:)8 W2 I, s0 f) j
3 G# @3 o3 c6 m3 o8 h, Y; N
^1 v: H7 T5 k, C3 {5 s- ?8 T! i
1 Q2 ?3 Z, [9 t+ r3 J2 q
|
zan
|