跳到主要内容

NOI 竞赛大纲

参考资料

难度系数
  • 入门级:151 \sim 5
  • 题高级:585 \sim 8
  • NOI 级:7107 \sim 10

1. 入门级

1.1 基础知识与编程环境

  1. 11 】计算机的基本构成(CPU、内存、I/O 设备等)
  2. 11 】Windows、Linux 等操作系统的基本概念及其常见操作
  3. 11 】计算机网络和 Internet 的基本概念
  4. 11 】计算机的历史和常见用途
  5. 11 】NOI 以及相关活动的历史
  6. 11 】NOI 以及相关活动的规则
  7. 11 】位、字节与字
  8. 11 】程序设计语言以及程序编译和运行的基本概念
  9. 11 】使用图形界面新建、复制、删除、移动文件或目录
  10. 11 】使用 Windows 系统下的集成开发环境(例如 Dev-C++ 等)
  11. 11 】使用 Linux 系统下的集成开发环境 (例如 Code::Blocks 等)
  12. 11 】g++、gcc 等常见编译器的基本使用

1.2 C++ 程序设计

  1. 程序基本概念
    • 11 】标识符、关键字、常量、变量、字符串、表达式的概念
    • 11 】常量与变量的命名、定义及作用
    • 22 】头文件与名字空间的概念
    • 22 】编辑、编译、解释、调试的概念
  2. 基本数据类型
    • 11 】整数型:intlong long
    • 11 】实数型:floatdouble
    • 11 】字符型:char
    • 11 】布尔型:bool
  3. 程序基本语句
    • 22cin 语句、scanf 语句、cout 语句、printf 语句、赋值语句、复合语句
    • 22if 语句、switch 语句、多层条件语句
    • 22for 语句、while 语句、do while 语句
    • 33 】多层循环语句
  4. 基本运算
    • 11 】算术运算:加、减、乘、除、整除、求余
    • 11 】关系运算:大于、大于等于、小于、小于等于、等于、不等于
    • 11 】逻辑运算:与(&&)、或(||)、非(!
    • 11 】变量自增与自减运算
    • 11 】三目运算
    • 22 】位运算:与(&)、或(|)、非(~)、异或(^)、左移(<<)、右移(>>
  5. 数学库常用函数
    • 33 】绝对值函数、四舍五入函数、下取整函数、上取整函数、平方根函数、常用三角函数、对数函数、指数函数
  6. 结构化程序设计
    • 11 】顺序结构、分支结构和循环结构
    • 22 】自顶向下、逐步求精的模块化程序设计
    • 22 】流程图的概念及流程图描述
  7. 数组
    • 11 】数组与数组下标
    • 11 】数组的读入与输出
    • 33 】二维数组与多维数组
  8. 字符串的处理
    • 22 】字符数组与相关函数
    • 22 】string 类与相关函数
  9. 函数与递归
    • 22 】函数定义与调用、形参与实参
    • 33 】传值参数与传引用参数
    • 22 】常量与变量的作用范围
  10. 结构体与联合体
    • 33 】结构体
    • 33 】联合体
  11. 指针类型
    • 44 】指针
    • 44 】基于指针的数组访问
    • 44 】字符指针
    • 44 】指向结构体的指针
  12. 文件及基本读写
    • 22 】文件的基本概念、文本文件的基本操作
    • 22 】文本文件类型与二进制文件类型
    • 22 】文件重定向、文件读写等操作
  13. STL 模板
    • 33 】算法模板库中的函数:minmaxswapsort
    • 44 】栈(stack)、队列(queue)、链表(list)、向量(vector)等容器

1.3 数据结构

  1. 线性结构
    • 33 】链表:单链表、双向链表、循环链表
    • 33 】栈
    • 33 】队列
  2. 简单树
    • 33 】树的定义与相关概念
    • 44 】树的表示与存储
    • 33 】二叉树的定义与基本性质
    • 44 】二叉树的表示与存储
    • 44 】二叉树的遍历:前序、中序、后序
  3. 特殊树
    • 44 】完全二叉树的定义与基本性质
    • 44 】完全二叉树的数组表示法
    • 44 】哈夫曼树的定义和构造、哈夫曼编码
    • 44 】二叉搜索树的定义和构造
  4. 简单图
    • 33 】图的定义与相关概念
    • 44 】图的表示与存储:邻接矩阵
    • 44 】图的表示与存储:邻接表

1.4 算法

  1. 算法概念与描述
    • 11 】算法概念
    • 22 】算法描述:自然语言描述、流程图描述、伪代码描述
  2. 入门算法
    • 11 】枚举法
    • 11 】模拟法
  3. 基础算法
    • 33 】贪心法
    • 33 】递推法
    • 44 】递归法
    • 44 】二分法
    • 44 】倍增法
  4. 数值处理算法
    • 44 】高精度的加法
    • 44 】高精度的减法
    • 44 】高精度的乘法
    • 44 】高精度整数除以单精度整数的商和余数
  5. 排序算法
    • 33 】排序的基本概念
    • 33 】冒泡排序
    • 33 】选择排序
    • 33 】插入排序
    • 33 】计数排序
  6. 搜索算法
    • 55 】深度优先搜索
    • 55 】广度优先搜索
  7. 图论算法
    • 44 】深度优先遍历
    • 44 】广度优先遍历
    • 55 】泛洪算法(flood fill)
  8. 动态规划
    • 44 】动态规划的基本思路
    • 44 】简单一维动态规划
    • 55 】简单背包类型动态规划
    • 55 】简单区间类型动态规划

1.5 数学与其他

  1. 数及其运算
    • 11 】自然数、整数、有理数、实数及其算术运算(加、减、乘、除)
    • 11 】进制与进制转换:二进制、八进制、十进制、十六进制
  2. 初等数学
    • 11 】代数(初中部分)
    • 11 】几何(初中部分)
  3. 初等数论
    • 33 】整除、因数、倍数、指数、质(素)数、合数
    • 33 】取整
    • 33 】模运算与同余
    • 33 】整数唯一分解定理
    • 33 】辗转相除法(欧几里得算法)
    • 44 】素数筛法:埃氏筛法与线性筛法
  4. 离散与组合数学
    • 22 】集合
    • 22 】加法原理
    • 22 】乘法原理
    • 44 】排列
    • 44 】组合
    • 44 】杨辉三角
  5. 其他
    • 22 】ASCII 码
    • 22 】格雷码

2. 题高级

2.1 基础知识与编程环境

  1. 55 】Linux 系统终端中常用的文件与目录操作命令
  2. 55 】Linux 系统下常见文本编辑工具的使用
  3. 55 】g++、gcc 等编译器与相关编译选项
  4. 55 】在 Linux 系统终端中运行程序,使用 time 命令查看程序用时
  5. 55 】调试工具 GDB 的使用

2.2 C++ 程序设计

  1. 类(class
    • 【 6 】类的概念及简单应用
    • 【 6 】成员函数和运算符重载
  2. STL 模板
    • 【 5 】容器(container)和迭代器(iterator
    • 【 5 】对(pair)、元组(tuple
    • 【 5 】集合(set)、多重集合(multiset
    • 【 5 】双端队列(deque)、优先队列(priority_queue
    • 【 5 】映射(map)、多重映射(multimap
    • 【 5 】算法模板库中的常用函数

2.3 数据结构

  1. 线性结构
    • 55 】双端栈
    • 55 】双端队列
    • 55 】单调队列
    • 66 】优先队列
    • 66 】ST 表(Sparse Table)
  2. 集合与森林
    • 66 】并查集
    • 66 】树的孩子兄弟表示法
  3. 特殊树
    • 66 】二叉堆
    • 66 】树状数组
    • 66 】线段树
    • 66 】字典树(Trie 树)
    • 77 】笛卡尔树
    • 88 】平衡树:AVL、treap、splay 等
  4. 常见图
    • 55 】稀疏图
    • 66 】偶图(二分图)
    • 66 】欧拉图
    • 66 】有向无环图
    • 77 】连通图与强连通图
    • 77 】双连通图
  5. 哈希表
    • 55 】数值哈希函数构造
    • 66 】字符串哈希函数构造
    • 66 】哈希冲突的常用处理方法

2.4 算法

  1. 复杂度分析
    • 66 】时间复杂度分析
    • 66 】空间复杂度分析
  2. 算法策略
    • 66 】离散化
  3. 基础算法
    • 66 】分治算法
  4. 排序算法
    • 55 】归并排序
    • 55 】快速排序
    • 66 】堆排序
    • 55 】桶排序
    • 66 】基数排序
  5. 字符串相关算法
    • 55 】字符串匹配:KMP 算法
  6. 搜索算法
    • 66 】搜索的剪枝优化
    • 66 】记忆化搜索
    • 77 】启发式搜索
    • 77 】双向广度优先搜索
    • 77 】迭代加深搜索
  7. 图论算法
    • 66 】最小生成树:Prim 和 Kruskal 等算法
    • 77 】次小生成树
    • 66 】单源最短路:Bellman-Ford、Dijkstra、SPFA 等算法
    • 77 】单源次短路
    • 66 】Floyd-Warshall 算法
    • 66 】有向无环图的拓扑排序
    • 66 】欧拉道路和欧拉回路
    • 66 】二分图的判定
    • 77 】强连通分量
    • 77 】割点、割边
    • 66 】树的重心、直径、DFS 序与欧拉序
    • 66 】树上差分、子树和与倍增
    • 66 】最近公共祖先
  8. 动态规划
    • 66 】树型动态规划
    • 77 】状态压缩动态规划
    • 88 】动态规划的常用优化

2.5 数学与其他

  1. 初等数学
    • 55 】代数(高中部分)
    • 66 】几何(高中部分)
  2. 初等数论
    • 55 】同余式
    • 77 】欧拉定理和欧拉函数
    • 77 】费马小定理
    • 77 】威尔逊定理
    • 77 】裴蜀定理
    • 77 】模运算意义下的逆元
    • 77 】扩展欧几里得算法
    • 77 】中国剩余定理
  3. 离散与组合数学
    • 66 】多重集合
    • 66 】等价类
    • 66 】多重集上的排列
    • 66 】多重集上的组合
    • 66 】错排列、圆排列
    • 66 】鸽巢原理
    • 66 】二项式定理
    • 77 】容斥原理
    • 77 】卡特兰(Catalan)数
  4. 线性代数
    • 55 】向量与矩阵的概念
    • 66 】向量的运算
    • 66 】矩阵的初等变换
    • 66 】矩阵的运算:加法、减法、乘法与转置
    • 66 】特殊矩阵的概念:单位阵、三角阵、对称阵和稀疏矩阵
    • 77 】高斯消元法

3. NOI 级

3.1 C++ 程序设计

  1. 88 】 面向对象的程序设计思想(OOP)

3.2 数据结构

  1. 线性结构
    • 88 】块状链表
  2. 序列
    • 99 】跳跃表
  3. 复杂树
    • 88 】树链剖分
    • 1010 】动态树:LCT
    • 88 】二维线段树
    • 99 】树套树
    • 99 】k-d 树
    • 1010 】虚树
  4. 可合并堆
    • 88 】左偏树
    • 1010 】二项堆
  5. 可持久化数据结构
    • 88 】可持久化线段树
    • 99 】其他可持久化数据结构

3.3 算法

  1. 算法策略
    • 88 】分块
    • 88 】离线处理思想
    • 99 】复杂分治思想
    • 99 】平衡规划思想
    • 99 】构造思想
  2. 字符串算法
    • 88 】Manacher 算法
    • 99 】扩展 KMP 算法
    • 88 】有穷自动机
    • 88 】AC 自动机
    • 88 】后缀数组
    • 99 】后缀树
    • 1010 】后缀自动机
  3. 图论算法
    • 88 】基环树
    • 1010 】最小树形图
    • 88 】2-SAT
    • 88 】网络流
    • 1010 】图的支配集、独立集与覆盖集
    • 88 】匈牙利算法
    • 99 】KM 算法
    • 1010 】一般图的匹配
  4. 动态规划
    • 99 】复杂动态规划模型的构建
    • 99 】复杂动态规划模型的优化

3.4 数学与其他

  1. 初等数论
    • 88 】原根和指数
    • 88 】大步小步(Baby Step Giant Step,BSGS)算法
    • 99 】狄利克雷(Dirichlet)卷积
    • 1010 】二次剩余
    • 1010 】二次同余式
  2. 离散与组合数学
    • 99 】群及其基本性质
    • 99 】置换群与循环群
    • 99 】母函数
    • 99 】莫比乌斯反演
    • 99 】Burnside 引理与 Pólya 定理
    • 99 】斯特林(Stirling)数
    • 99 】无根树的 Prüfer 序列
  3. 线性代数
    • 99 】逆矩阵
    • 99 】行列式
    • 99 】向量空间与线性相关
  4. 高等数学
    • 88 】多项式函数的微分
    • 88 】多项式函数的积分
    • 1010 】泰勒(Taylor)级数
    • 1010 】快速傅里叶变换
  5. 概率论
    • 88 】概率的基本概念
    • 1010 】随机变量的期望与方差
    • 99 】条件概率
    • 99 】贝叶斯公式
  6. 博弈论
    • 99 】尼姆(Nim)博弈
    • 99 】SG 函数
  7. 最优化
    • 1010 】单纯形法
  8. 计算几何
    • 88 】点、线、面之间位置关系的判定
    • 88 】一般图形面积的计算
    • 88 】二维凸包
    • 99 】半平面交
  9. 信息论
    • 1010 】熵、互信息、条件熵、相对熵
  10. 其他
    • 1010 】信息复杂度的概念
    • 1010 】描述复杂度的概念
    • 1010 】通讯复杂度的概念