ACM常用算法及练习(2)
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)的更多相关文章
- ACM常用算法及练习(1)
ACM常用算法及练习 第一阶段:练经典常用算法,下面的每个算法给我打上十到二十遍,同时自己精简代码,因为太常用,所以要练到写时不用想,10-15分钟内打完,甚至关掉显示器都可以把程序打出来. 1.最短 ...
- ACM常用算法
数据结构 栈,队列,链表 哈希表,哈希数组 堆,优先队列 双端队列 可并堆 左偏堆 二叉查找树 Treap 伸展树 并查集 集合计数问题 二分图的识别 平衡二叉树 二叉排序树 线段树 一维线段树 二维 ...
- 总结Objective-c常用算法
今天是星期天,想睡到10点起床,结果认为自己太奢侈了,不能这么做,于是把闹钟设置成了6:30:结果终于9:36醒了,起床,无缘无故迟了,好吧,就算太累了吧,周天就原谅自己一回.终于到了中午 ...
- Atitit 编程语言常用算法attilax总结
Atitit 编程语言常用算法attilax总结 1. 编译算法分类and 数据操作算法.1 1.1. Tab driver stat 状态转换表格算法1 1.2. Nest case 词法分析 ...
- GJM : 数据结构 - 轻松看懂机器学习十大常用算法 [转载]
转载请联系原文作者 需要获得授权,非法转载 原文作者将享受侵权诉讼 文/不会停的蜗牛(简书作者)原文链接:http://www.jianshu.com/p/55a67c12d3e9 通过本篇文章可以 ...
- acm常见算法及例题
转自:http://blog.csdn.net/hengjie2009/article/details/7540135 acm常见算法及例题 初期:一.基本算法: (1)枚举. (poj17 ...
- C/C++常用算法【C语言顺序查找(随机数)】【1】
这是我学习唐峻,李淳的<C/C++常用算法第一天> 1.8.1. 查找数字: 程序随机生成一个拥有20个整数数据的数组,然后输入要查找的数据.接着,可以采用醉简单的逐个对比的方法进行查找, ...
- Python之路,Day21 - 常用算法学习
Python之路,Day21 - 常用算法学习 本节内容 算法定义 时间复杂度 空间复杂度 常用算法实例 1.算法定义 算法(Algorithm)是指解题方案的准确而完整的描述,是一系列解决问题的 ...
- python 下的数据结构与算法---2:大O符号与常用算法和数据结构的复杂度速查表
目录: 一:大O记法 二:各函数高阶比较 三:常用算法和数据结构的复杂度速查表 四:常见的logn是怎么来的 一:大O记法 算法复杂度记法有很多种,其中最常用的就是Big O notation(大O记 ...
随机推荐
- mina学习(一)
Mina:是一个帮助用户开发高性能和高伸缩性网络应用程序的框架 学习地址链接:http://www.cnblogs.com/xuekyo/archive/2013/03/06/2945826.html ...
- myeclipse 8.5 常用快捷键【转】
eclipse 里查找行号的方法 今天开发的时候为了方便查找报错行的位置,特意在网上找了一下快捷键是什么,现做记录. 在Eclipse里的show the line number 后,使用" ...
- 利用sqlserver日志恢复数据
如果你已经急的焦头烂额,看到这篇文章的时候,请你换个坐姿,深呼吸几次,静下心来将这篇文章读完,也许你的问题迎刃而解. 我遇 到的情况是这样的,网站被植入木马,盗取了我的web.config文件,web ...
- 初次接触Groovy
其实我这两年业余时间一直断断续续的在学java,水平还不怎么样,不过起码能参与小项目写写接口了.现在我决定暂时放下大众的java,改学小众的Groovy,只因为我新拿到个offer,对方公司的自动化框 ...
- IE中的fireEvent和webkit中的dispatchEvent
拿浏览器的click事件来说: 在IE浏览器中如果一个element没有注册click事件,那么直接调用的话会出现异常!当然如果你注册了没有什么可说的. 那么如果使用fireEvent来处理,clic ...
- CSS3新添加的选择器
---条件选择器:--- .ccc[cusid*= value] { backgroud-color:#0094ff; } //表示使用了class="ccc"元素自定义属性cus ...
- Nodejs电影建站开发实例(上)
网站环境:使用express框架.bootstrap样式.jade模板.mongoose数据库 npm insatll express -g npm insatll jada -g npm insat ...
- PMP--论文部分
个人观点,是三个部分最简单,最容易复习的,当然,如果你没有做好一个项目的摘要和正文的背诵,连各个过程的工具输输入输出的都记不住几个,就不用往下看了,以上内容的观点,至少保证真题做三次以上,书籍教材看三 ...
- contentOffset,frame,bounds,contentSize,ContentInset
contentOffset, 在UIScrollview里面滚动条用的最多,比如网易新闻的滚动条,肯定会用到这个. 我认为:它是下一个要显示的图片的左上角.设置了这个左上角后,下一次滚动时,邮戳直接到 ...
- JS-008-日期控件操作
此文以 js 操作 layDate 日期组件为示例演示,进行日期修改. 相应的演示示例脚本,敬请参阅之前的博文:HTML-001-日期组件 layDate 演示. 操作结果如下所示: 至此, JS-0 ...