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. 【转】android UI进阶之自定义组合控件

    [源地址]http://blog.csdn.net/notice520/article/details/6667827 好久没写博客了.实在是忙不过来,不过再不总结总结真的不行了.慢慢来吧,有好多需要 ...

  2. Nginx 常用全局变量 及Rewrite规则详解

    每次都很容易忘记Nginx的变量,下面列出来了一些常用 $remote_addr //获取客户端ip $binary_remote_addr //客户端ip(二进制) $remote_port //客 ...

  3. php+mysql实现事务回滚

    模拟条件:第一个表插入成功,但是第二个表插入失败,回滚.第一个表插入成功,第二个表插入成功,执行.第一个表插入失败,第二个表插入成功,回滚.第一个表插入失败,第二个表插入失败,回滚.以上情况都需要回滚 ...

  4. linux环境下的伪分布式环境搭建

    本文的配置环境是VMware10+centos2.5. 在学习大数据过程中,首先是要搭建环境,通过实验,在这里简短粘贴书写关于自己搭建大数据伪分布式环境的经验. 如果感觉有问题,欢迎咨询评论. 一:伪 ...

  5. Qt 2D绘图 渐变填充(三种渐变方式)

    在qt中提供了三种渐变方式,分别是线性渐变,圆形渐变和圆锥渐变.如果能熟练应用它们,就能设计出炫目的填充效果. 线性渐变: 1.更改函数如下: void Dialog::paintEvent(QPai ...

  6. Qt与VS2005/2008的完美配合(自己编译Qt4.5.1的详细步骤)

    介绍 用过Linux的人想必都知道Qt(不是QuickTime,呵呵)这个名称,KDE就是用Qt写的,我也是接触Linux后才认识它的. Qt原先是奇趣科技TM(Trolltech)的产品,由Haav ...

  7. PM2的使用

    PM2 是一个带有负载均衡功能的 Node 应用的进程管理器. 安装 npm install -g pm2 启动程序:pm2 start <app_name|id|all> 列举进程:pm ...

  8. VLC说明

    一.简介 vlc的全名是Video Lan Client,是一个开源的.跨平台的视频播放器.VLC支持大量的音视频传输.封装和编码格式,完整的功能特性列表可以在这里获得http://www.video ...

  9. Magento: How to reset admin pssword

    Magento: How to reset admin pssword If you forget your admin password for Magento and you can’t reme ...

  10. zero1--hibernate注解02