数学建模社区-数学中国
标题:
ACM练习建议
[打印本页]
作者:
fisher_jiang
时间:
2006-10-18 01:09
标题:
ACM练习建议
<p>一位高手对我的建议:<br/> <br/> 一般要做到50行以内的程序不用调试、100行以内的二分钟内调试成功.acm主要是考算法的<br/>,主要时间是花在思考算法上,不是花在写程序与debug上。 <br/>下面给个计划你练练:<br/> <br/>第一阶段:<br/> 练经典常用算法,下面的每个算法给我打上十到二十遍,同时自己精简代码,<br/>因为太常用,所以要练到写时不用想,10-15分钟内打完,甚至关掉显示器都可以把程序打<br/>出来. <br/> 1.最短路(Floyd、Dijstra,BellmanFord) <br/> 2.最小生成树(先写个prim,kruscal要用并查集,不好写) <br/> 3.大数(高精度)加减乘除 <br/> 4.二分查找. (代码可在五行以内) <br/> 5.叉乘、判线段相交、然后写个凸包. <br/> 6.BFS、DFS,同时熟练hash表(要熟,要灵活,代码要简) <br/> 7.数学上的有:辗转相除(两行内),线段交点、多角形面积公式. <br/> 8. 调用系统的qsort, 技巧很多,慢慢掌握. <br/> 9. 任意进制间的转换 </p><p><br/>第二阶段:<br/> 练习复杂一点,但也较常用的算法。 <br/>如: <br/> 1. 二分图匹配(匈牙利),最小路径覆盖 <br/> 2. 网络流,最小费用流。 <br/> 3. 线段树. <br/> 4. 并查集。 <br/> 5. 熟悉动态规划的各个典型:LCS、最长递增子串、三角剖分、记忆化dp <br/> 6.博弈类算法。博弈树,二进制法等。 <br/> 7.最大团,最大独立集。 <br/> 8.判断点在多边形内。 <br/> 9. 差分约束系统. <br/>10. 双向广度搜索、A*算法,最小耗散优先.</p><p><br/>第三阶段:<br/> 前两个阶段是打基础,第三阶段是锻炼在比赛中可以快速建立模型、想新算法<br/>。这就要平时多做做综合的题型了。 <br/> 1. 把oibh上的论文看看(大概几百篇的,我只看了一点点,呵呵)。 <br/> 2. 平时扫扫zoj上的难题啦,别老做那些不用想的题.(中大acm的版主经常说我挑简单的来<br/>做:-P ) <br/> 3. 多参加网上的比赛,感受一下比赛的气氛,评估自己的实力. <br/> 4. 一道题不要过了就算,问一下人,有更好的算法也打一下。 <br/> 5. 做过的题要记好 :-) <br/> </p>
作者:
asialuo
时间:
2006-10-23 18:39
我只停留在第一阶段...
作者:
liuzhao
时间:
2006-11-26 01:09
建议很好,我就想这么去做了~
作者:
946976
时间:
2006-12-16 20:39
支持一下先
作者:
nkxiaoqi
时间:
2006-12-20 22:20
ACM题目确实要求很强的算法能力
作者:
Fantasy_FC
时间:
2006-12-27 14:35
不错啊!支持一下
作者:
kakana
时间:
2007-1-5 17:35
好
作者:
taochenpfj
时间:
2007-1-13 19:58
ding a wo xiang xue dian
作者:
pengyou0594
时间:
2007-1-26 23:29
感谢楼主,给我指明了方向
作者:
cedricmht
时间:
2007-5-31 23:02
<p>你是一盏明灯呀</p><p>为我指明了方向呀</p><p></p>
作者:
fansmiling
时间:
2007-6-18 12:21
<p>~~~good</p><p></p>
作者:
心如往事
时间:
2007-7-30 09:47
我连第一阶段都上不了手。
作者:
colorShine
时间:
2007-8-24 00:50
感谢楼主了啊,这建议不错啊,我现在还停留在第一阶段,真是惭愧啊,惭愧啊,我准备从现在开始就这样做,看看啥时候能到第三阶段。呵呵,加油啊加油啊……
作者:
wangyexin
时间:
2007-10-7 13:38
<p>谢谢提醒</p>
作者:
术兀
时间:
2007-10-9 02:45
<p>谢谢</p><p>虽然……</p><p>但是</p><p>还是谢谢喽</p><p></p>
作者:
pipiaishuxue
时间:
2009-11-6 20:46
支持一下,顶
作者:
厚积薄发
时间:
2009-12-2 11:28
顶啊,支持
作者:
nwpupanda
时间:
2009-12-3 20:33
支持下啦O(∩_∩)O~不过偶还只是停留在第一阶段的前一阶段啊。。。。。。。。。。。
作者:
hetao220284
时间:
2009-12-3 20:53
现在来顶 不会晚吧。。。。。。。。。。。。。。。。。。。。。。。
作者:
540982016044
时间:
2010-1-21 10:24
看来我是不行了
~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
作者:
chip
时间:
2010-1-21 16:19
非常感谢楼主分享,顶一下先了。
作者:
yhytju
时间:
2010-1-23 11:09
一位高手对我的建议:
) \7 C" a3 ^% T j* w
4 U0 C' }/ F1 ~3 n/ Q! x
一般要做到50行以内的程序不用调试、100行以内的二分钟内调试成功.acm主要是考算法的
# B6 W+ c+ N( M; C9 x) W8 t# p
,主要时间是花在思考算法上,不是花在写程序与debug上。
4 W( d+ g: F. w9 T [: Q
下面给个计划你练练:
1 ^& l6 p2 |3 p( x/ q
, N! r! q& G! f' ?8 P
第一阶段:
2 k2 U+ N0 W6 g, x& m" Z
练经典常用算法,下面的每个算法给我打上十到二十遍,同时自己精简代码,
- w/ K/ \' X* `3 T H+ Y
因为太常用,所以要练到写时不用想,10-15分钟内打完,甚至关掉显示器都可以把程序打
: i X' H4 L) n8 m: A
出来.
N: X% O' ]# J/ c$ h6 i5 q
1.最短路(Floyd、Dijstra,BellmanFord)
: P0 q8 \9 _1 x n( o6 B
2.最小生成树(先写个prim,kruscal要用并查集,不好写)
' E' a& I# Z* r$ v! P7 Z$ F
3.大数(高精度)加减乘除
8 {" v: F, O3 }" W0 y5 Y
4.二分查找. (代码可在五行以内)
/ g7 B& P8 I/ q
5.叉乘、判线段相交、然后写个凸包.
. e. c/ C/ I N7 v
6.BFS、DFS,同时熟练hash表(要熟,要灵活,代码要简)
U" m6 H+ n1 j) |
7.数学上的有:辗转相除(两行内),线段交点、多角形面积公式.
' H' r5 p) q8 W* }+ c8 d
8. 调用系统的qsort, 技巧很多,慢慢掌握.
^) J3 T$ G/ T0 c
9. 任意进制间的转换
K, b- e% X8 e( ]/ |
! ~& m1 Y3 A9 u' @
: z u0 U5 C; w! J% e4 {/ X. |
第二阶段:
) u: w! Y. O; E( Z. N
练习复杂一点,但也较常用的算法。
$ ], l7 f* u' ]5 e2 f
如:
% E4 H# a+ m& q) } g3 I& D
1. 二分图匹配(匈牙利),最小路径覆盖
! z' t6 { [ E& w. V0 M
2. 网络流,最小费用流。
- d% P; e( ?' x8 U
3. 线段树.
) X$ y8 _# ]3 W9 e1 {
4. 并查集。
% H4 g+ f: d2 I4 ^$ V1 j! G- l
5. 熟悉动态规划的各个典型:LCS、最长递增子串、三角剖分、记忆化dp
% q+ _1 [5 |! K/ _- i
6.博弈类算法。博弈树,二进制法等。
: a; }, A- Z @ R, [$ T) ~3 F) U$ v
7.最大团,最大独立集。
" @; O N9 J, U. k* b
8.判断点在多边形内。
! [( ]! X- o5 f5 c7 J
9. 差分约束系统.
Z, @; A4 Z9 W1 C; G7 T
10. 双向广度搜索、A*算法,最小耗散优先.
" i0 _! H6 c* k% O* v$ T
( E* l% f# V& u2 T
- C9 E; {" i3 ?$ r' w# T
第三阶段:
. @0 K. s E+ s3 [4 \( R
前两个阶段是打基础,第三阶段是锻炼在比赛中可以快速建立模型、想新算法
+ A; w$ b' ?) O! b
。这就要平时多做做综合的题型了。
4 b0 L3 w- b# |' o% p) `
1. 把oibh上的论文看看(大概几百篇的,我只看了一点点,呵呵)。
8 V b) V* U7 l! O6 e
2. 平时扫扫zoj上的难题啦,别老做那些不用想的题.(中大acm的版主经常说我挑简单的来
/ }$ I7 ^! m! {4 p! ^* Y3 N
做:-P )
3 M! }% f3 a6 ~* z
3. 多参加网上的比赛,感受一下比赛的气氛,评估自己的实力.
, X( W$ C( i3 J3 u+ ]) a: H
4. 一道题不要过了就算,问一下人,有更好的算法也打一下。
' A: a0 z. [/ m* c4 V( Z% `+ O
5. 做过的题要记好 :-)
作者:
兄弟
时间:
2010-1-28 13:57
顶!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!顶!!!!!!!!!!!!!!!!
作者:
LM386
时间:
2010-1-28 13:58
顶!!!!!!!!!!!!!!!
作者:
silecainengai
时间:
2010-4-12 08:29
方向有了,不知道啥时候才能到那种高度!
作者:
pingpangbing
时间:
2010-4-29 19:35
可以试试可以试试可以试试可以试试可以试试可以试试
作者:
mightyrock
时间:
2010-5-8 19:15
哎,如此强大,怎是人人都能达到的呀?看来我还有一万光年的差距呀!
作者:
qnbs1
时间:
2010-5-15 18:00
正在第一阶段...唉.加油吧.........
作者:
xiaojinwen
时间:
2010-5-26 23:28
回复
10#
cedricmht
, L# _# b6 a* _1 I3 Q/ h
0 N! u$ T7 _/ X3 X1 h4 r5 _
, v/ m( ~+ O) O2 G6 Y5 f" v
我在努力!一直没有停过!
作者:
kevin2234
时间:
2010-6-2 18:54
是啊,是啊!
作者:
moyan
时间:
2010-10-14 21:56
朝这个方向好好努力!!!!!!!
作者:
John8169
时间:
2011-1-31 21:17
其实我一直觉得楼主的品味不错!呵呵!
/ |( Q7 U# o' z0 |
数学中国社区越来越好!
/ Y% v6 O$ l' ?$ r3 r& N9 K
作者:
鸿光满面
时间:
2011-2-1 18:39
我还在地下一层
作者:
鸿光满面
时间:
2011-2-3 16:17
ding
作者:
葉_浅浅
时间:
2011-2-17 18:19
其实我一直觉得楼主的品味不错!呵呵!
$ _+ m/ u5 V" g
我一天不来数学中国社区就不爽~~~~
) Y5 E3 ^. n+ r+ `1 _4 ^0 T# i
作者:
shuizhizi
时间:
2011-3-5 13:27
唉,这样下来绝对是编程牛人,但是过程很痛苦赛
作者:
华夏之龙
时间:
2011-5-6 07:04
bucuo a 支持一下。谢谢啊
作者:
zhuhuaij
时间:
2011-5-8 00:10
既然你诚信诚意的推荐了,那我就勉为其难的听听吧!
' m' B0 i6 r; p" z# |+ b
数学中国社区越来越好!
作者:
qingmuda
时间:
2011-5-20 15:06
支持,学习~
作者:
O_young_man
时间:
2011-5-24 19:21
Thank you!
作者:
巧云225
时间:
2011-6-10 13:39
好,真不错
作者:
江南刹
时间:
2011-7-17 19:52
还没开始做ZOJ上的题呢!
作者:
dailifeng
时间:
2011-8-28 08:37
支持一下
作者:
中耿苍安
时间:
2011-10-26 00:39
谢谢你的发言` 非常有意义
作者:
Jackge
时间:
2011-11-20 21:45
吼吼……………………
作者:
枫泯
时间:
2012-1-23 20:04
这个,嗯.十分好的建议
作者:
nandehutugood
时间:
2012-11-9 12:09
感谢楼主,感谢楼主,
欢迎光临 数学建模社区-数学中国 (http://www.madio.net/)
Powered by Discuz! X2.5