【C++】全国青少年信息学奥林匹克竞赛(NOI)入门级-目录

【C++】全国青少年信息学奥林匹克竞赛(NOI)入门级大纲

【C++】C++从入门到NOI学习路线

一、基础知识与编程环境

1. 计算机的基本构成(CPU、内存、I/O 设备等)

2. Windows、Linux 等操作系统的基本概念及其常见操作

3. 计算机网络和 Internet 的基本概念

4. 计算机的历史和常见用途

5. NOI 以及相关活动的历史

6. NOI 以及相关活动的规则

7. 位、字节与字

8. 程序设计语言以及程序编译和运行的基本概念

9. 使用图形界面新建、复制、删除、移动文件或目录

10. 使用 Windows 系统下的集成开发环境( 例如 Dev C++ 等 )

11. 使用 Linux 系统下的集成开发环境 ( 例Code::Blocks 等 )

12. g++、gcc 等常见编译器的基本使用

二、C++ 程序设计

1. 程序基本概念

1.1 标识符、关键字、常量、变量、字符串、表达式的概念
1.2 常量与变量的命名、定义及作用
1.3 头文件与名字空间的概念
1.4 编辑、编译、解释、调试的概念

2. 基本数据类型

2.1 整数型:int 、 long long
2.2 实数型:float、 double
2.3 字符型:char
2.4 布尔型:bool

3. 程序基本语句

3.1 cin 语句、scanf 语句、cout 语句、printf语句、赋值语句、复合语句
3.2 if 语句、switch 语句、多层条件语句
3.3 for 语句、while 语句、do while 语句
3.4 多层循环语句

4. 基本运算

4.1 算术运算:加、减、乘、除、整除、求余
4.2 关系运算:大于、大于等于、小于、小于等于、等于、不等于
4.3 逻辑运算:与(&&)、或(||)、非(!)
4.4 变量自增与自减运算
4.5 三目运算
4.6 位运算:与(&)、或(|)、非(~)、异或(^)、左移(<<)、右移(>>)

5. 数学库常用函数

5.1 绝对值函数、四舍五入函数、下取整函数、上取整函数、平方根函数、常用三角函数、对数函数、指数函数

6. 结构化程序设计

6.1 顺序结构、分支结构和循环结构
6.2 自顶向下、逐步求精的模块化程序设计
6.3 流程图的概念及流程图描述

7. 数组

7.1 数组与数组下标
7.2 数组的读入与输出
7.3 二维数组与多维数组

8. 字符串的处理

8.1 字符数组与相关函数
8.2 string 类与相关函数

9. 函数与递归

9.1 函数定义与调用、形参与实参
9.2 传值参数与传引用参数
9.3 常量与变量的作用范围
9.4 递归函数

10. 结构体与联合体

10.1 结构体
10.2 联合体

11. 指针类型

11.1 指针
11.2 基于指针的数组访问
11.3 字符指针
11.4 指向结构体的指针

12. 文件及基本读写

12.1 文件的基本概念、文本文件的基本操作
12.2 文本文件类型与二进制文件类型
12.3 文件重定向、文件读写等操作

13. STL 模板

13.1 算法模板库中的函数:min、max、swap、sort
13.2 栈 (stack)、队列 (queue)、链表 (list)、向量(vector)等容器

三、数据结构

1. 线性结构

1.1 链表:单链表、双向链表、循环链表
1.2 栈
1.3 队列

2. 简单树

2.1 树的定义与相关概念
2.2 树的表示与存储
2.3 二叉树的定义与基本性质
2.4 二叉树的表示与存储
2.5 二叉树的遍历:前序、中序、后序

3. 特殊树

3.1 完全二叉树的定义与基本性质
3.2 完全二叉树的数组表示法
3.3 哈夫曼树的定义和构造、哈夫曼编码
3.4 二叉搜索树的定义和构造

4. 简单图

4.1 图的定义与相关概念
4.2 图的表示与存储:邻接矩阵
4.3 图的表示与存储:邻接表

四、算法

1. 算法概念与描述

1.1 算法概念
1.2 算法描述:自然语言描述、流程图描述、伪代码描述

2. 入门算法

2.1 枚举法
2.2 模拟法

3. 基础算法

3.1 贪心法
3.2 递推法
3.3 递归法
3.4 二分法
3.5 倍增法

4. 数值处理算法

4.1 高精度的加法
4.2 高精度的减法
4.3 高精度的乘法
4.4 高精度整数除以单精度整数的商和余数

5. 排序算法

5.1 排序的基本概念
5.2 冒泡排序
5.3 选择排序
5.4 插入排序
5.5 计数排序

6. 搜索算法

6.1 深度优先搜索
6.2 广度优先搜索

7. 图论算法

7.1 深度优先遍历
7.2 广度优先遍历
7.3 泛洪算法(flood fill)

8. 动态规划

8.1 动态规划的基本思路
8.2 简单一维动态规划
8.3 简单背包类型动态规划
8.4 简单区间类型动态规划

五、数学与其他

1. 数及其运算

1.1 自然数、整数、有理数、实数及其算术运算(加、减、乘、除)
1.2 进制与进制转换:二进制、八进制、十进制、十六进制

2. 初等数学

2.1 代数(初中部分)
2.2 几何(初中部分)

3. 初等数论

3.1 整除、因数、倍数、指数、质(素) 数、合数
3.2 取整
3.3 模运算与同余
3.4 整数唯一分解定理
3.5 辗转相除法(欧几里得算法)
3.6 素数筛法:埃氏筛法与线性筛法

4. 离散与组合数学

4.1 集合
4.2 加法原理
4.3 乘法原理
4.4 排列
4.5 组合
4.6 杨辉三角

5. 其他

5.1 ASCII 码
5.2 格雷码

你可能感兴趣的:(C++从零基础入门到NOI竞赛,c++)