数学建模社区-数学中国

标题: ACM练习建议 [打印本页]

作者: fisher_jiang    时间: 2006-10-18 01:09
标题: ACM练习建议
<p>一位高手对我的建议:<br/>&nbsp;<br/>&nbsp;&nbsp;&nbsp;&nbsp; 一般要做到50行以内的程序不用调试、100行以内的二分钟内调试成功.acm主要是考算法的<br/>,主要时间是花在思考算法上,不是花在写程序与debug上。&nbsp; <br/>下面给个计划你练练:<br/>&nbsp; <br/>第一阶段:<br/>&nbsp;&nbsp;&nbsp; 练经典常用算法,下面的每个算法给我打上十到二十遍,同时自己精简代码,<br/>因为太常用,所以要练到写时不用想,10-15分钟内打完,甚至关掉显示器都可以把程序打<br/>出来.&nbsp; <br/>&nbsp;1.最短路(Floyd、Dijstra,BellmanFord)&nbsp; <br/>&nbsp;2.最小生成树(先写个prim,kruscal要用并查集,不好写)&nbsp; <br/>&nbsp;3.大数(高精度)加减乘除&nbsp; <br/>&nbsp;4.二分查找. (代码可在五行以内)&nbsp; <br/>&nbsp;5.叉乘、判线段相交、然后写个凸包.&nbsp; <br/>&nbsp;6.BFS、DFS,同时熟练hash表(要熟,要灵活,代码要简)&nbsp; <br/>&nbsp;7.数学上的有:辗转相除(两行内),线段交点、多角形面积公式.&nbsp; <br/>&nbsp;8. 调用系统的qsort, 技巧很多,慢慢掌握.&nbsp; <br/>&nbsp;9. 任意进制间的转换 </p><p><br/>第二阶段:<br/>&nbsp;&nbsp;&nbsp; 练习复杂一点,但也较常用的算法。&nbsp; <br/>如:&nbsp; <br/>&nbsp;1. 二分图匹配(匈牙利),最小路径覆盖&nbsp; <br/>&nbsp;2. 网络流,最小费用流。&nbsp; <br/>&nbsp;3. 线段树.&nbsp; <br/>&nbsp;4. 并查集。&nbsp; <br/>&nbsp;5. 熟悉动态规划的各个典型:LCS、最长递增子串、三角剖分、记忆化dp&nbsp; <br/>&nbsp;6.博弈类算法。博弈树,二进制法等。&nbsp; <br/>&nbsp;7.最大团,最大独立集。&nbsp; <br/>&nbsp;8.判断点在多边形内。&nbsp; <br/>&nbsp;9. 差分约束系统.&nbsp; <br/>10. 双向广度搜索、A*算法,最小耗散优先.</p><p><br/>第三阶段:<br/>&nbsp;&nbsp;&nbsp; 前两个阶段是打基础,第三阶段是锻炼在比赛中可以快速建立模型、想新算法<br/>。这就要平时多做做综合的题型了。&nbsp; <br/>&nbsp;1. 把oibh上的论文看看(大概几百篇的,我只看了一点点,呵呵)。&nbsp; <br/>&nbsp;2. 平时扫扫zoj上的难题啦,别老做那些不用想的题.(中大acm的版主经常说我挑简单的来<br/>做:-P )&nbsp; <br/>&nbsp;3. 多参加网上的比赛,感受一下比赛的气氛,评估自己的实力.&nbsp; <br/>&nbsp;4. 一道题不要过了就算,问一下人,有更好的算法也打一下。&nbsp; <br/>&nbsp;5. 做过的题要记好 :-)&nbsp;&nbsp;&nbsp; <br/>&nbsp; </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&nbsp; wo&nbsp; 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/ h0 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