【转】学习路线3

来源:互联网 发布:平凉切纸机数据 编辑:程序博客网 时间:2024/06/05 17:18

原文链接

1. 掌握C++语法,并熟练使用STL

2. 试着实现STL的一些基本容器和函数,使自己基本能看懂STL源码

3. 图论

a) 使用优先队列优化Dijkstra和Prim

b) 单源最短路径之SPFA

c) 差分约束系统

d) 多源多点最短路径之FloydWarshall算法

e) 求欧拉路(圈套圈算法)

4. 进行复杂模拟题训练

5. 拓扑排序

6. 动态规划进阶

a) 完全背包、多重背包等各种背包问题(参见背包九讲)

b) POJ上完成一定数目的动态规划题目

c) 状态压缩动态规划

d) 树形动态规划

7. 搜索

a) 回溯法熟练应用

b) 复杂的搜索题目练习

c) 双向广度优先搜索

d) 启发式搜索(包括A*算法,如八数码问题)

8. 计算几何

a) 判断点是否在线段上

b) 判断线段相交

c) 判断矩形是否包含点

d) 判断圆与矩形关系

e) 判断点是否在多边形内

f) 判断点到线段的最近点

g) 计算两个圆的公切线

h) 求矩形的并的面积

i) 求多边形面积

j) 求多边形重心

k) 求凸包

9. 可以学习一种C++的开发框架来编写一些窗体程序玩玩(如MFC,Qt等)。

10. 学习使用C或C++连接数据库。