计算机算法与竞赛,计算机算法竞赛学习指南.doc

PAGE / NUMPAGES

需要学好的专业课程

C/C++语言

高等数学

线性代数

数据结构

离散数学

数据库原理

操作系统原理

计算机组成原理

人工智能

编译原理

算法设计与分析

准备阶段的学习计划

第一阶段:

必修

1. C语言基础语法必须全部学会

a) 推荐“语言入门”分类20道题以上

b) 提前完成C语言课程设计

2. 简单数学题

需要掌握以下基本算法:

a) 欧几里德算法求最大公约数

b) 筛法求素数

c) 康托展开

d) 逆康托展开

e) 同余定理

f) 次方求模

3. 计算几何初步

a) 三角形面积

b) 三点顺序

4. 学会简单计算程序的时间复杂度与空间复杂度

5. 二分查找法

6. 简单的排序算法

a) 冒泡排序法

b) 插入排序法

7. 贪心算法经典题目

选修:

8. 学会使用简单的DOS命令(较重要)

a) color/dir/copy/shutdown/mkdir(md)/rmdir(rd)/attrib/cd/ b) 知道什么是绝对路径与相对路径 c) 学会使用C语言调用DOS命令 d) 学会在命令提示符下调用你自己用C语言编写的程序,并使用命令行参数给自己的程序传参(比如自己制作一个copyfile.exe实现与copy命令基本功能一致的功能)资料个人收集整理,勿做商业用途

e) 学会编写bat批处理文件

9. 学会Windows系统的一些小知识,如设置隐藏文件,autoRun.inf的设置等。

10. 学会编辑注册表(包括使用注册表编辑器regedit和使用DOS命令编辑注册表)

11. 学会使用组策略管理器管理(gpedit.msc)组策略。

第二阶段:

1. 掌握C++部分语法,如引用类型,函数重载等,基本明白什么是类。

2. 学会BFS与DFS

a) 迷宫求解(最少步数)

b) 水池数目(NYOJ27)

c) 图像有用区域(NYOJ92)

d) 树的前序中序后序遍历

3. 动态规划,要学会使用循环的方法写动态规划,同时也要学会使用记忆化搜索的方法。

a) 最大子串和

b) 最长公共子序列

c) 最长单调递增子序列(O(n)与O(n log n)算法都需要掌握)

d) 01背包

e) RMQ算法

4. 学会分析与计算复杂程序的时间复杂度

5. 学会使用栈与队列等线性存储结构

6. 学会分治策略

7. 排序算法

a) 归并排序

b) 快速排序

c) 计数排序

8. 数论

a) 扩展欧几里德算法

b) 求逆元

c) 同余方程

d) 中国剩余定理

9. 博弈论

a) 博弈问题与SG函数的定义

b) 多个博弈问题SG值的合并

10. 图论:

a) 图的邻接矩阵与邻接表两种常见存储方式

b) 欧拉路的判定

c) 单最短路bellman-ford算法dijkstra算法

d) 最小生成树的kruskal算法与prim算法

11. 学会使用C语言进行网络编程与多线程编程

12. 线性代数

a) 明确线性代数的重要性,首先是课本必须学好

b) 编写一个Matrix类,进行矩阵的各种操作,并求编写程序解线性方程组

c) 推荐做一两道“矩阵运算”分类下的题目

选修:

13. 使用C语言或C++编写简单程序来调用一些简单的windows API,或者在linux下进行linux系统调用,其目的是明白什么是API(应用程序接口)资料个人收集整理,勿做商业用途

14. 网页设计

a) 学习静态网页技术(html+css+javascript)

b) 较具有艺术细胞的可以试试Photoshop

c) php或其它动态网页技术

15. 学习matlab,如果想参加数学建模大赛的话,需要学这个软件

  • 2
    点赞
  • 7
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值