来源:彪神发的训练文档
                                                                     ACM 训练大纲
                                                                                                 
Changsha University of Science & Technology
July 31, 2012                                                                                                                                                 

 1 推荐题库

• http://ace.delos.com/usaco/

美国的OI 题库,如果是刚入门的新手,可以尝试先把它刷通,能够学到几乎全部的基础算法极其优化,

全部的题解及标程还有题目翻译可以baidu 一个叫NOCOW 的网站。


• http://livearchive.onlinejudge.org/

上面有全部的赛区真题,绝大部分都可以提交,不适合当题库刷,不过在这里找题非常方便。


• http://poj.org/

不解释了,中国最知名的oj,题量非常之大,历史也很悠久,推荐刷一些代表性的题目。


• http://acm.timus.ru/
Ural 大学的oj,国外oj 中非常好的一个,题目非常锻炼基本功,管理员会不时添加一些新数据rejudge,

推荐找些通过人数适中的题目割一割。


• http://acm.sgu.ru/

SGU 大学的oj,题目比较经典(比较老,几百年不更新了),不是特别推荐。


• http://www.spoj.pl
比较奇葩的一个oj,有一些与众不同的提交模式,也有很多著名的系列题目,qtree 等,题目质量很好,

但问题是国内的题解较少,新手如果只是想去割水题还是不要去了。


• http://acm.hdu.edu.cn
航电大学的oj,亮点是上面独有的中国多校联合训练的题目,而且有一版(貌似是20 开头的那版)水题

大全,新手提高很不错。


• http://acm.zju.edu.cn

每个月定时有月赛,浙大出题非常靠谱,推荐每个月月赛可以做一做。


• http://acm.hust.edu.cn
华中科技大学的oj,也就是各大oj 著名的virtual judge(三国五虎上将)的始作俑者,亮点就是那个模

拟比赛的功能异常好用,平时大家可以自己配题做做模拟比赛。


• http://www.codeforces.com
著名线上比赛网站,几乎每周都有一场线上比赛,有各国牛人参加,强烈推荐按时参加提高实力(要克

服时差问题)。


• http://www.topcoder.com/tc
更著名的一个线上比赛网站,历史相当悠久,而且有丰富的奖金,强烈推荐去做algorithm 比赛的single

round match,非常提高智商。

2 算法总结及推荐题目

2.1 C++ STL

• STL 容器: set, map, vector, priority_queue, queue, stack, deque, bitset
• STL 算法: sort, unique, nth_element, reverse, rotate, next_permution, find, for_each, count, lower_bound,

max, swap, random_shuffle

2.2 基本算法

• 枚举: poj1753, poj2965, zoj1716, zoj3356, ural1010
• 贪心: poj1328, poj2109, poj2586, ural1303, sgu195, sgu171
• 递归与分治: ural1181, poj1579, poj1845, poj3714
• 构造: poj3922, poj1092, sgu121
• 模拟: poj3125, poj1068, poj2993, ural1007
• 排序: ural1082, poj2092, poj1694
• KMP 算法: poj2406
• 扩展KMP: poj3376, poj1699
• 二分法: poj1905, poj2002
• 三分法: hdu3400, hdu2298
• 矩阵乘法: zoj2105, zoj3289
• 离散化: ural1019, sgu177
• 快速傅立叶变换: poj2821

• 环状字符串最小表示: poj1509

2.3 图论


• 深度优先遍历: poj2488
• 宽度优先遍历: poj3620, poj2251
• 最短路: poj1847, poj1062
• 最小生成树: zoj1914
• 拓扑排序: zoj2193, zoj1060
• 二分图最大匹配: poj1469
• 二分图的最大权匹配: ural1076
• 稳定婚配问题: poj3487
• 最大流与最小割: poj1459
• 带下界的最大流: poj2396
• 最小费用最大流: poj2159
• 差分约束系统: poj1275
• 双连通分量: zoj2588
• 强连通分量: zoj2470, poj2186
• 割边及割点: poj3352, poj3177
• 度限制生成树: poj1638, hdu3070
• K 短路: poj2449, sgu145
• 最近公共祖先: poj1330
• 最优比率生成树: poj2728
• 次小生成树: poj1679
• 最小树形图: poj3164
• 欧拉回路与路径: poj1386, poj2337
• 哈密顿回路: sgu122
• 旅行商问题: poj2288
• 极大团搜索: poj2989
• 弦图的判定与应用: zoj1015

• 任意图的最大匹配: ural1099

2.4 数据结构


• 栈与队列: poj2559
• 并查集: poj1611, poj1182
• 哈希表: poj1840, poj1186
• 优先队列: poj1862, poj3253
• 可合并堆: zoj2334
• 字母树及AC 自动机: zoj3430, zoj3228
• 线段树: zoj3317, zoj1610
• 树状数组: poj2299, poj2352
• 倍增表(RMQ): poj3368, poj2452
• 平衡二叉树: poj2892, poj2418, poj3580
• 后缀数组: poj2774, poj3294
• KD 树: spoj2835, poj2528
• 树链剖分: poj3237, spoj2666, spoj2798
• 树的分治算法: poj2114, poj1987

• 动态树: hdu2475, hdu3601, hdu4010

2.5 搜索


• 简单技巧与剪枝: poj1033, poj3009
• 最优化与可行性剪枝: poj1011, poj1190
• 记忆化搜索: poj1191, poj1088
• 迭代加深: poj2286, poj2032
• A 搜索: hdu2467, poj1077
• Dancing Link: poj3074, hdu4069
• 折半搜索: zoj3631
• 双向广搜: poj1198, poj1915

2.6 动态规划

• 资源分配问题: poj3624, poj2063
• 区间划分问题: poj3280
• 状态压缩问题: poj1185
• 树形DP: poj1463, poj3345
• 数据结构优化DP: poj2374, poj2355
• 四边形不等式: poj1160
• 队列优化: zoj3399
• 插头表示的状态压缩DP: poj1739
• 最小表示法的状态压缩DP: spoj2159

• 数位DP: hdu3555, sgu258, sgu390

2.7 数学


• 排列组合: poj1850, poj3252
• Lucas 定理: poj3219
• 素数测试与筛法: poj2191, poj1811
• 大数分解的快速算法: poj1142
• 进位制: poj2798, poj1702
• 同余模运算: poj1006, poj2115
• 容斥原理: poj3904, poj1173
• 置换群与Burnside 引理: poj2888
• 递推关系与母函数: poj3734
• 高斯消元: poj1681, poj1222
• 概率与统计: poj2151, poj1021
• 扩展欧几里得算法: poj2891, poj1061
• 中国剩余定理: poj1006, zoj3538
• 离散对数与离散根: sgu261
• 拉格朗日插值: uva4209
• 迭代逼近: poj2868, poj3933
• 莫比乌斯反演: poj2154
• 博弈论与SG 函数: poj2960, poj2311
• 偏序论与格: poj1065, poj3636

2.8 计算几何


• 点积与叉积: zoj1010
• 线段相交: zoj1648
• 简单多边形的面积: poj1654
• 点到线段的最近最远距离: ural1348
• 凸包: poj1113
• 对锺点: poj2187
• 圆与点的切线: poj1375
• 圆与直线的交: poj1263
• 圆与圆的交: poj2564
• 圆与多边形的并与交: poj3675
• 点在多边形内: poj2398
• 半平面交: poj1474, poj2540
• 最小圆覆盖: zoj1450, spoj145
• 三维凸包: poj3528
• 三维点与直线的表示: poj3129

• 线性规划: poj1755

3 推荐书籍


• 《Introduction to Algorithms》
著名的算法大全,囊括全部的基础算法,其详尽程度超乎想象,而且都做了不同程度的扩展,若能同时

配合做一做上面的习题,受益匪浅。


• 《算法艺术与信息学竞赛》
俗称黑书,lrj 的成名之作,非常开拓视野,推荐阅读并掌握。另外,lrj 最近出了一本白书,我没读过,

听说更加基础,有兴趣的同学可以去读一读。


• 《Concrete Mathematics》
计算机学科的必备书籍之一,该书几乎包括计算机科学用到的全部数学知识,如果感兴趣,推荐深入阅

读更专业的书籍(组合数学、初等数论、离散数学、线性代数等等)。


• 《How to solve it》
这一本与上面基本不同,讲的是怎样解题,一本可以帮助你更好地数学建模抽象问题的书籍,不光对竞

赛,对整个思维方式都有帮助。


• 《Computational Geometry Algorithms and Applications》
相当详细的一本计算几何书籍,计算几何往往是一场比赛中最考研基本功最不需要思维复杂度的题目,

练好计算几何对比赛相当有利。


• 《C++ 程序设计思想与方法》
对C++ 语言特性不熟悉的同学建议看看,很好的一本介绍C++ 语言的书籍,有余力的建议再学个

java,写大模拟题、高精度题都有巨大优势。


• 全部的NOI 国家集训队作业以及论文
在网上全部可以找到,非常好的资料,都是历年的强手将当时最先进的知识整理所得,也包括不少题库
的题解。

ACM 训练大纲【CSUST_ACM】相关推荐

  1. ACM 训练大纲(CSUST_ACM)

    ACM 训练大纲 Changsha University of Science & Technology July 31, 2012 1 推荐题库 • http://ace.delos.com ...

  2. 网内计算:可编程数据平面和技术特定应用综述

    网内计算:可编程数据平面和技术特定应用综述 摘要--与云计算相比,边缘计算提供了更靠近终端设备的处理,降低了用户体验的延迟.最新的In-Network Computing范例采用可编程网络元素在数据达 ...

  3. 初学ACM之路(训练大纲)

    初期: 一.基本算法: (1)枚举. (poj1753,poj2965) (2)贪心(poj1328,poj2109,poj2586) (3)递归和分治法. (4)递推. (5)构造法.(poj329 ...

  4. [JS]在ACM模式下获取输入

    输入输出处理 核心代码模式处理 不需要处理任何输入输出,直接返回值即可. ACM 模式 你的代码需要处理输入输出,请使用如下样例代码读取输入和打印输出: while (line = readline( ...

  5. 九度OJ 1339:ACM (排序)

    时间限制:1 秒 内存限制:32 兆 特殊判题:否 提交:712 解决:379 题目描述: 今年的ACM世界总决赛快要开始了,需要有一个排名算法来对每支队伍进行现场排名.ACM组委会把这个任务交给了你 ...

  6. 【转】[退役]纪念我的ACM——headacher@XDU

    转自:http://hi.baidu.com/headacher/item/5a2ce1d50609091b20e25022 退役了,是时候总结一下我ACM的生涯了.虽然很舍不得,但这段回忆很值得纪念 ...

  7. 做acm 需要学的算法

    做acm 需要学的算法 转一个搞ACM需要的掌握的算法.  要注意,ACM的竞赛性强,因此自己应该和自己的实际应用联系起来.  适合自己的才是好的,有的人不适合搞算法,喜欢系统架构,因此不要看到别人什 ...

  8. [置顶]2010年东北大学ACM程序设计竞赛冬季校赛题解

    8题只做出4题比较easy的题,而且做得挺麻烦,看来还要多练练. AC的题如下 NEUOJ  1112 I Love Apple Description So many people love app ...

  9. HDOJ 1157 HDU 1157 Who's in the Middle ACM 1157 IN HDU

    MiYu原创, 转帖请注明 : 转载自 ______________白白の屋   题目地址: http://acm.hdu.edu.cn/showproblem.php?pid=1157 题目描述: ...

最新文章

  1. 常用广告类型的包装代码示例
  2. 今日头条女程序员加班加到不来大姨妈,凌晨十二点半回家的她竟然还被老板吐槽不投入!妹子抑郁大哭!...
  3. linux挂载分区失败,Ubuntu分区挂载错误与Grub引导错误的修复
  4. 操作系统与虚拟化安全第一次作业-关键习题
  5. java mysql 多表查询_MySQL必备知识多表查询
  6. AI艺术的发展:让艺术通过人工智能变得更具创造力和人性化
  7. python文件去重_python实现文件内容去重
  8. 哈工大教授车万翔:基于迁移学习的任务型对话系统
  9. jenkins停止僵尸作业Click here to forcibly terminate running steps
  10. 轻轻松松实现角度转换(弧度度分秒)
  11. 主要发达国家大数据政策比较研究
  12. apache ab linux 下载,linux 下ab压力测试
  13. 在线教育凛冬将至!强敌环伺的尚德机构,能否突出重围?
  14. springboot发送邮件(QQ邮箱)
  15. Android实现有声计算器代码,有声语音计算器效果与代码
  16. Java微信公众平台开发(一)--接入微信公众平台
  17. 中国大学MOOC数据库系统概论中国人民大学实验三 触发器
  18. JAVA进阶知识点总结 4-Map HashMap LinkedHashMap Map的遍历方式 斗地主案例
  19. Argox(立象)打印机
  20. 喜来登“手牵手”家庭计划率先亮相大中华区13家度假酒店

热门文章

  1. 物联网将IT安全推向边缘
  2. primer练习11.14
  3. 成都电子科技大学计算机尹佳,电子科技大学成都研究院
  4. segment的理解
  5. 企业邮箱对比免费邮箱,国内邮箱申请哪家好?邮箱哪个安全可靠?
  6. iPhone机型适配相关问题
  7. 通达OA 工作流电子签章 盖章Or手写
  8. 读书笔记 - 《史蒂夫·乔布斯传》
  9. tl-wn821n linux驱动程序,Kali Linux安装TL-WN821N USB无线网卡驱动(make失败)
  10. 盛世昊通联手民族品牌CaldiceKris,创造价值互联