ACM常用算法及练习

知识类型 重要度 容易度 应掌握度 典型题 其他
         
数据结构(5) 链表 ★★☆ ★★★ ★★☆    
栈 stack ★★★ ★★★ ★★★ HLoj1207 HDoj_1022
队列 queue ★★★ ★★★ ★★★    
并查集 ★★★ ★★☆ ★★★ HDoj_1213 HLoj1050
二叉堆和优先队列 ★★☆ ★★★ ★★☆ HDoj_1873  
二叉排序树 ★☆☆ ★★☆ ★☆☆    
字典树(Trie) ★★☆ ★☆☆ ★☆☆ HDoj_1251  
线段树 ★★☆ ★☆☆ ★★☆ Zoj_1514 Hdoj_1556
Hash表 ★★☆ ★★☆ ★★☆ HDoj_1800 HDoj_1880
树状数组 ★☆☆ ★☆☆ ★☆☆    
             
STL(1) Container          
vector ★★★ ★★★ ★★★    
list ★★☆ ★★★ ★★☆ HLoj_1053  
queue ★★★ ★★★ ★★★    
stack ★★★ ★★★ ★★★ HLoj1207 HDoj_1022
set ★★☆ ★★☆ ★★☆ Hdoj_1106, Hdoj_1412  
map ★★★ ★☆☆ ★★★ HDoj_1800  
Algorithm          
sort ★★★ ★★★ ★★★    
reverse ★★★ ★★★ ★★★ HDoj_1266  
find ★★☆ ★☆☆ ★★☆    
max_element/min_element ★★☆ ★☆☆ ★☆☆ HDoj_2025  
replace ★★☆ ★★☆ ★☆☆ Zoj_2741  
             
数学(1) 最大公约(最小公倍) ★★★ ★★★ ★★★ HDoj_1019  
扩展欧几里德算法 ★☆☆ ★☆☆ ★☆☆ HDoj_2669  
素数判定(eratosthenes筛选法) ★★★ ★★★ ★★★ HLoj_1232 HDoj_1262
同余 ★★☆ ★★☆ ★★☆ HDoj_1420 HDoj_1395
利用log来降低计算难度 ★☆☆ ★★☆ ★☆☆ HDoj_1060  
进制转换 ★★★ ★★★ ★★★    
高精度,大整数 ★★★ ★★☆ ★★★    
           
Fibonacci ★★★ ★★☆ ★★★ HDoj_2070 HLoj_1020,HLoj_1186
Catalan ★★☆ ★☆☆ ★☆☆ HDoj_1134  
欧拉函数 ★★☆ ★☆☆ ★☆☆ HDoj_2824 Hdoj_1787
约瑟夫问题 ★★☆ ★★☆ ★★☆ HLoj_1185 HDoj_2925
stirling数 ★☆☆ ★☆☆ ★☆☆ HDoj_2512  
             
图论(3) 哈夫曼树,最优二叉树 ★☆☆ ★☆☆ ★☆☆ HDoj_1053  
图的表示          
邻接矩阵 ★★★ ★★★ ★★★    
邻接表 ★★☆ ★★☆ ★★☆    
最短路径          
Dijkstra ★★★ ★★☆ ★★☆ HDoj_1874  
Floyd ★★☆ ★★★ ★★☆ HDoj_1869  
最小生成树          
Prim ★★★ ★★☆ ★★★ HLoj_1014 HDoj_1102
Kruscal ★★★ ★★☆ ★★★ HDoj_1232  
图的遍历          
连通图判断(BFS,DFS) ★★★ ★★☆ ★★★ HDoj_1878  
其他          
拓扑排序 ★☆☆ ★☆☆ ★☆☆ HDoj_1285  
欧拉图(一笔画问题)判断 ★★☆ ★★☆ ★★☆ HDoj_1878  
二部图与匈牙利算法最大独立集 ★★☆ ★☆☆ ★★☆ HDoj_1068  
网络流(5) ★☆☆ ★☆☆ ★☆☆    
             
算法(2) 递归和分治 ★★☆ ★★☆ ★★☆ Zoj2922 Zoj2855
           
贪心算法          
会场安排问题 ★★☆ ★★☆ ★★☆ HLoj_1203 HDoj_2037
不完全背包问题 ★★★ ★★★ ★★★ HDoj_1009  
           
动态规划          
1、最长上升子序列 LIS ★★★ ★★☆ ★★★ HDoj_1257 HLoj_1064
2、最长公共子序列 LCS ★★★ ★★☆ ★★★ HDoj_1159 HDoj_3779
3、递推 ★★☆ ★★☆ ★★☆ HLoj_1041 HDoj_2044-2050
4、母函数 ★☆☆ ★★☆ ★☆☆ HDoj_1171 HDoj_1709
5、数塔类 ★★★ ★★★ ★★★ HDoj_2084 HDoj_1176
6、最大子段类 ★★★ ★★☆ ★★★    
最大子段和 ★★★ ★★☆ ★★★ HDoj_1231 HDoj_1422
最大子阵和 ★★★ ★☆☆ ★★☆ HDoj_1559 HDoj_1081
最大m子段和 ★☆☆ ★☆☆ ★☆☆ HLoj_7011  
7、背包问题          
01背包,完全背包,多重背包 ★★★ ★★☆ ★★★ HLoj_1006 HDoj_3732
二维背包 ★★★ ★★☆ ★★☆ HLoj_1039 HDoj_3496
有依赖的背包 ★★☆ ★☆☆ ★☆☆ HLoj_1067  
           
8、树形DP ★★☆ ★☆☆ ★☆☆ HDoj_1520  
9、DP之备忘录,记忆化搜索 ★★★ ★★☆ ★★☆ Poj_1088 HDoj_1078,HDoj_3779
           
回溯DFS          
子集树 ★★★ ★★☆ ★★★ HLoj_1004  
排列树 ★★★ ★★☆ ★★☆ HLoj_1004 HLoj_1227,HDoj_1572
           
分支限界BFS          
BFS ★★★ ★★☆ ★★☆ HDoj_1242 HLoj_1241
             
其他(1)            
找规律/周期 ★★☆ ★★☆ ★★☆ HDoj_1005 HDoj_1061
打表/备忘录方式 ★☆☆ ★★☆ ★☆☆ HDoj_2041 HDoj_2212
大整数处理(加,减,乘) ★★★ ★★★ ★★★ Hdoj_1592 Hdoj_1316
串流stringstream ★★★ ★★☆ ★★★ HDoj_2072  
博弈 ★☆☆ ★☆☆ ★☆☆    
             
几何(1) 叉积/面积 点/线/多边形        
基本形 两直线相交/两线段相交/点在任意多边形内的判定        
相关判定          
凸包          

未完待续~~~

ACM常用算法及练习(2)的更多相关文章

  1. ACM常用算法及练习(1)

    ACM常用算法及练习 第一阶段:练经典常用算法,下面的每个算法给我打上十到二十遍,同时自己精简代码,因为太常用,所以要练到写时不用想,10-15分钟内打完,甚至关掉显示器都可以把程序打出来. 1.最短 ...

  2. ACM常用算法

    数据结构 栈,队列,链表 哈希表,哈希数组 堆,优先队列 双端队列 可并堆 左偏堆 二叉查找树 Treap 伸展树 并查集 集合计数问题 二分图的识别 平衡二叉树 二叉排序树 线段树 一维线段树 二维 ...

  3. 总结Objective-c常用算法

          今天是星期天,想睡到10点起床,结果认为自己太奢侈了,不能这么做,于是把闹钟设置成了6:30:结果终于9:36醒了,起床,无缘无故迟了,好吧,就算太累了吧,周天就原谅自己一回.终于到了中午 ...

  4. Atitit 编程语言常用算法attilax总结

    Atitit 编程语言常用算法attilax总结 1. 编译算法分类and   数据操作算法.1 1.1. Tab driver stat  状态转换表格算法1 1.2. Nest case 词法分析 ...

  5. GJM : 数据结构 - 轻松看懂机器学习十大常用算法 [转载]

     转载请联系原文作者 需要获得授权,非法转载 原文作者将享受侵权诉讼 文/不会停的蜗牛(简书作者)原文链接:http://www.jianshu.com/p/55a67c12d3e9 通过本篇文章可以 ...

  6. acm常见算法及例题

    转自:http://blog.csdn.net/hengjie2009/article/details/7540135 acm常见算法及例题  初期:一.基本算法:     (1)枚举. (poj17 ...

  7. C/C++常用算法【C语言顺序查找(随机数)】【1】

    这是我学习唐峻,李淳的<C/C++常用算法第一天> 1.8.1. 查找数字: 程序随机生成一个拥有20个整数数据的数组,然后输入要查找的数据.接着,可以采用醉简单的逐个对比的方法进行查找, ...

  8. Python之路,Day21 - 常用算法学习

    Python之路,Day21 - 常用算法学习   本节内容 算法定义 时间复杂度 空间复杂度 常用算法实例 1.算法定义 算法(Algorithm)是指解题方案的准确而完整的描述,是一系列解决问题的 ...

  9. python 下的数据结构与算法---2:大O符号与常用算法和数据结构的复杂度速查表

    目录: 一:大O记法 二:各函数高阶比较 三:常用算法和数据结构的复杂度速查表 四:常见的logn是怎么来的 一:大O记法 算法复杂度记法有很多种,其中最常用的就是Big O notation(大O记 ...

随机推荐

  1. mina学习(一)

    Mina:是一个帮助用户开发高性能和高伸缩性网络应用程序的框架 学习地址链接:http://www.cnblogs.com/xuekyo/archive/2013/03/06/2945826.html ...

  2. myeclipse 8.5 常用快捷键【转】

    eclipse 里查找行号的方法 今天开发的时候为了方便查找报错行的位置,特意在网上找了一下快捷键是什么,现做记录. 在Eclipse里的show the line number 后,使用" ...

  3. 利用sqlserver日志恢复数据

    如果你已经急的焦头烂额,看到这篇文章的时候,请你换个坐姿,深呼吸几次,静下心来将这篇文章读完,也许你的问题迎刃而解. 我遇 到的情况是这样的,网站被植入木马,盗取了我的web.config文件,web ...

  4. 初次接触Groovy

    其实我这两年业余时间一直断断续续的在学java,水平还不怎么样,不过起码能参与小项目写写接口了.现在我决定暂时放下大众的java,改学小众的Groovy,只因为我新拿到个offer,对方公司的自动化框 ...

  5. IE中的fireEvent和webkit中的dispatchEvent

    拿浏览器的click事件来说: 在IE浏览器中如果一个element没有注册click事件,那么直接调用的话会出现异常!当然如果你注册了没有什么可说的. 那么如果使用fireEvent来处理,clic ...

  6. CSS3新添加的选择器

    ---条件选择器:--- .ccc[cusid*= value] { backgroud-color:#0094ff; } //表示使用了class="ccc"元素自定义属性cus ...

  7. Nodejs电影建站开发实例(上)

    网站环境:使用express框架.bootstrap样式.jade模板.mongoose数据库 npm insatll express -g npm insatll jada -g npm insat ...

  8. PMP--论文部分

    个人观点,是三个部分最简单,最容易复习的,当然,如果你没有做好一个项目的摘要和正文的背诵,连各个过程的工具输输入输出的都记不住几个,就不用往下看了,以上内容的观点,至少保证真题做三次以上,书籍教材看三 ...

  9. contentOffset,frame,bounds,contentSize,ContentInset

    contentOffset, 在UIScrollview里面滚动条用的最多,比如网易新闻的滚动条,肯定会用到这个. 我认为:它是下一个要显示的图片的左上角.设置了这个左上角后,下一次滚动时,邮戳直接到 ...

  10. JS-008-日期控件操作

    此文以 js 操作 layDate 日期组件为示例演示,进行日期修改. 相应的演示示例脚本,敬请参阅之前的博文:HTML-001-日期组件 layDate 演示. 操作结果如下所示: 至此, JS-0 ...