码迷,mamicode.com
首页 > 其他好文 > 详细

CSP-S 初赛问题求解与选择题

时间:2019-10-05 12:47:18      阅读:216      评论:0      收藏:0      [点我收藏+]

标签:字符串   include   tor   自动分配   杨辉三角   相同   委员会   结构   存储   

# CSP-S 初赛问题求解与选择题

## 时间复杂度计算

公式:对于 $T(n) = a \times T(\dfrac{n}{b})+O(n^d)$ 这个递推式,其时间复杂度为:
$$
T(n) =
\begin{cases}
O(n^{\log_b a}) , \ a > b^d \\
\\
O(n^d \lg n) , \ a = b^d \\
\\
O(n^d) , \ a<b^d
\end{cases}
$$


## 鸽巢原理

### 基本定义

若有 $n$ 个鸽巢,$n+1$ 只鸽子,则至少有一个鸽巢里至少有两只鸽子。

变形:

1. 一年 $365$ 天,今有 $366$ 个人,则其中至少有两个人生日相同。
2. 抽屉里有 $10$ 双手套,从中取 $11$ 只出来,其中至少有两只是完整配对的。

### 经典例题

1. ($NOIP \ 2012$ )如果平面上任取 $n$ 个整点(横纵坐标都是整数),其中一定存在 $2$ 个点,它们连线的中点也是整点,那么 $n$ 至少是( )。

**解:**存在 $2$ 个点中点是整点,要求两点横纵坐标奇偶性都相同。根据鸽巢原理,$n$ 至少是 $2 \times 2+1=5$

2. 在边长为 $1$ 的正方形内任取 $5$ 点,则其中至少有 $2$ 点的距离不超过( )。

**解:**如下图所示,将一个正方形分成四份,那么至少有 $2$ 个点在同一个小正方形里面。在同一个正方形里面的两点最长距离即为 $\dfrac{\sqrt{2}}{2}$ 。

![1570161350854](C:\Users\Administrator\AppData\Roaming\Typora\typora-user-images\1570161350854.png)

3. 证明:一位国际象棋大师有 $11$ 周的时间备战比赛,他决定每天至少下 $1$ 盘棋,但每周不超过 $12$ 盘。则存在连续若干天,他恰好下了 $21$ 盘棋。

**解:**令 $a_i$ 为到第 $i$ 天下的总盘数,那我们要证明存在 $i,j$ 满足 $a_i+21=a_j$ 。

? $\because$ 他每天至少下 $1$ 盘棋

? $\therefore$ $a_i$ 是单调递增的

? $\therefore$ $1 < a_1 < a_2 < \ldots < a_{77} < 11 \times 12=132$

? $\therefore$ $22 < a_1+21 < a_2+21 < \ldots < a_{77}+21 < 132+21=153$

? 上下两式总共有 $153$ 种取值,却有 $154$ 个数,所以存在 $i < j$ 满足 $a_i+21=a_j$。

### 加强形势

现有鸽巢 $n$ 个,鸽子 $m_1+m_2+ \cdots +m_n-n+1$ 只,其中 $m_1,m_2, \ldots ,m_n, n \in \N^*$

**结论:**鸽巢 $1$ 鸽子数 $> m_1$,或鸽巢 $2$ 鸽子数 $> m_2$,…… 或鸽巢 $n$ 鸽子数 $> m_n$,至少有一个成立。

### 扩展内容:Erdös-Szekeres 定理

在由 $n^2+1$ 个实数构成的序列中,必然含有长为 $n+1$ 的单调(增或减)子序列。

 

## Ramsey 问题

命题:$6$ 人中或者至少存在 $3$ 人互相认识,或者至少存在 $3$ 人互相不认识。

等价问题:六个顶点的完全图的边,用红、蓝二色任意着色,则至少存在一红色边三角形,或一蓝色边三角形。

 

## 排列组合

### 前置知识

$A_n^n = n! $

$A_n^m = n(n-1)(n-2) \cdots (n-m+1) = \dfrac{n!}{(n-m)!}$

$C_n^m = \dfrac{A_n^m}{A_m^m} = \dfrac{n(n-1)(n-2) \cdots (n-m+1)}{m!} = \dfrac{n!}{m!(n-m)!} $

另外,规定 $C_n^0 = 1$

圆排列(在一个圆里,经旋转后相同算同一种解):$Q_n^r = \dfrac{A_n^r}{r} = \dfrac{n!}{r \cdot (n-r)!}$

### 重要定理及证明

1. $\ C_n^m = C_n^{n-m}$

我们可以这么想:组合就是从 $n$ 个元素中随机抽出 $m$ 个元素,那这样和从 $n$ 个元素中抽出 $n-m$ 个元素保留不是一个道理吗?所以就有了这个公式:$\ C_n^m = C_n^{n-m}$

2. $C_{n+1}^m = C_n^m + C_n^{m-1}$ **【记牢,经常用!!!】**

> 方法1:我们可以这么想:假设集合 $A$ 中现在有 $n+1$ 个元素,分别为 $a_1,a_2,\cdots,a_{n+1}$ ,那么从集合 $A$ 中抽出 $m$ 个元素,就可以分类讨论:如果抽出的元素中不含有 $a_1$ ,那么就是从 $n$ 个元素中抽出 $m$ 个元素,一共有 $C_n^m$ 种;如果抽出的元素中含有 $a_1$,那么就有 $C_n^{m-1}$ 种方法。所以 $C_{n+1}^m = C_n^m + C_n^{m-1}$。
>
> 方法2:阶乘证明:
>
> $\because$ 左边 $=$ $\dfrac{(n+1)!}{m!(n+1-m)!}$
>
> $\because$ 右边 $= $ $\dfrac{n!}{m!(n-m)!} + \dfrac{n!}{(m-1)!(n+1-m)!} = \dfrac{n!(n-m+1)}{m!(n+1-m)!} + \dfrac{n! \cdot m}{m!(n+1-m)!} = \dfrac{(n+1)!}{m!(n+1-m)!}$
>
> $\therefore$ 左边 $=$ 右边
>
> $\therefore \ C_{n+1}^m = C_n^m + C_n^{m-1}$
>
> 方法3:杨辉三角形的任意一个数都等于它肩上的两个数之和,再结合二项式定理,就可以得出这个规律。

3. $C_n^m = \dfrac{m+1}{n+1} C_{n+1}^{m+1}$

同样,这里也可以用阶乘来证明:

$\because$ 左边 $=$ $\dfrac{n!}{m!(n-m)!} $

$\because$ 右边 $=$ $\dfrac{m+1}{n+1} \cdot \dfrac{(n+1)!}{(m+1)!(n+1-m-1)!} = \dfrac{m+1}{n+1} \cdot \dfrac{(n+1)!}{(m+1)!(n-m)!} = \dfrac{m+1}{n+1} \cdot \dfrac{n! (n+1)}{m!(n-m)!(m+1)} = \dfrac{n!}{m!(n-m)!}$

$\therefore$ 左边 $=$ 右边

$\therefore$ $C_n^m = \dfrac{m+1}{n+1} C_{n+1}^{m+1}$

4. 一个含有 $n \ (n \in N^*)$ 个元素的集合 $A = \{ a_1,a_2,\cdots , a_n \}$,不同的子集又 $2^n$ 个。

### 二项式定理

1. 俗话来说,就是**杨辉三角形**!

2. 二项式定理公式:
$$
\large (a+b)^n = C_n^0a^n + C_n^1a^{n-1}b^1 + \cdots + C_n^ka^{n-k}b^k + \cdots +C_n^nb^n (n \in N^*)
$$

3. 二项式定理通项:
$$
\large T_{k+1} = C_n^ka^{n-k}b^k
$$

4. 二项式系数之和:

令 $(a+b)^n = C_n^0a^n + C_n^1a^{n-1}b^1 + \cdots + C_n^ka^{n-k}b^k + \cdots +C_n^nb^n (n \in N^*)$,那么 $C_n^0 + C_n^1 + \cdots + C_n^n = 2^n$

> 证明:
>
> 用赋值法,令 $a = b = 1$,那么 $(a+b)^n = C_n^0 + C_n^1 + \cdots + C_n^n = (1+1)^n = 2^n$

5. 二项式系数最值问题:

都知道杨辉三角形其实是一个十分对称的三角形,每一行的最大值就是在这一行最中间的那个数。对于 $(a+b)^n$,展开后只要关注$\dfrac{n}{2}$ 的值。如果 $\dfrac{n}{2}$ 的值是整数,那么二项式系数的最大值就是 $C_n^{\frac{n}{2}}$ ;反之,如果 $\dfrac{n}{2}$ 是小数,那么二项式系数的最大值就是 $C_n^{[\frac{n}{2}]} , C_n^{[\frac{n}{2}]+1}$ ( $[x]$ 表示对 $x$ 向下取整)。

### 错位排列

问题:有 $n$ 个信封和 $n$ 个信箱,分别编号为 $1$ 到 $n$,相同编号的信封和信箱不能放一起,则有几种方法?

公式:$f(n)=(n-1)(f(n-1)+f(n-2))$

错位排列的前几项:$0,1,2,9,44,265$

**并不是所有的问题都适用排列组合,视情况而定!**

 

## 卡特兰数

### 公式

先看这个问题:在 $n \times n$ 的网格里从左下角走到右上角的不经过 $y = x$ 这条线的单调路径的条数。

![](D:\卡特兰数.png)

路径条数即为:$\dbinom{n}{2n} - \dbinom{n-1}{2n} = \dfrac{1}{n+1} \dbinom{n}{2n}$

卡特兰数通式即为:$C_n = \dbinom{n}{2n} - \dbinom{n-1}{2n} = \dfrac{1}{n+1} \dbinom{n}{2n}$

卡特兰数的递推公式 $1$:$C_n = C_0 \times C_{n-1} + C_1 \times C_{n-2} + \cdots + C_{n-1} \times C_0,C_0 = 1$

卡特兰数的递推公式 $2$:$C_n = \dfrac{C_{n-1} \times (4 \times n - 2)}{n+1}$

### 应用

1. 求带限制条件的路径条数

2. 求合法的括号序列的个数

3. 求出栈次序

4. 买票找票问题:有 $2n$ 个人排成一行进入剧场。入场费 $5$ 元。其中只有 $n$ 个人有一张 $5$ 元钞票,另外 $n$ 人只有 $10$ 元钞票,剧院无其它钞票,问有多少种方法使得只要有 $10$ 元的人买票,售票处就有 $5$ 元的钞票找零?(将持 $5$ 元者到达视作将 $5$ 元入栈,持 $10$ 元者到达视作使栈中某 $5$ 元出栈)

5. 排队问题:现在有 $2n$ 个人,他们身高互不相同,他们要成两排,每一排有 $n$ 个人,并且满足每一排必须是从矮到高,且后一排的人要比前一排对应的人要高,问有多少种方案。

6. 凸多边形三角划分:在一个凸多边形中,通过若干条互不相交的对角线,把这个多边形划分成了若干个三角形。任务是输入凸多边形的边数 $n$,求不同划分的方案数 $f(n)$。

7. 给定节点构成二叉搜索树

 

## 指针问题

### 指针定义

C语言里,变量存放在内存中,而内存其实就是一组有序字节组成的数组,每个字节有唯一的内存地址。CPU 通过内存寻址对存储在内存中的某个指定数据对象的地址进行定位。这里,数据对象是指存储在内存中的一个指定数据类型的数值或字符串,它们都有一个自己的地址,而指针便是保存这个地址的变量。也就是说:**指针是一种保存变量地址的变量**。

### 如何定义一个指针

指针其实就是一个变量,指针的声明方式与一般的变量声明方式没太大区别,下面举了几个栗子:

```cpp
int *p; // 声明一个 int 类型的指针 p
char *p // 声明一个 char 类型的指针 p
int *arr[10] // 声明一个指针数组,该数组有10个元素,其中每个元素都是一个指向 int 类型对象的指针
int (*arr)[10] // 声明一个数组指针,该指针指向一个 int 类型的一维数组
int **p; // 声明一个指针 p ,该指针指向一个 int 类型的指针
```

声明一个指针变量并不会自动分配任何内存。在对指针进行间接访问之前,指针必须进行初始化:或是使他指向现有的内存,或者给他动态分配内存,否则我们并不知道指针指向哪儿。同时,对指针进行初始化后,便可以正常对指针进行赋值了。 初始化的操作如下:

```cpp
/* 方法:使指针指向现有的内存 */
int x = 1;
int *p = &x;  // 指针 p 被初始化,指向变量 x ,其中取地址符 & 用于产生操作数内存地址
```

就如下面这个程序,输出为:`1 2`

```cpp
#include <bits/stdc++.h>

int main(){
int x = 1;
int *p = &x;
printf("%d ",*p);
  *p = 2;
printf("%d\n",*p);

return 0;
}
```

### NULL指针

NULL 指针是一个特殊的**指针变量**,表示不指向任何东西。可以通过给一个指针赋一个零值来生成一个 NULL 指针。

### 指针的运算

1. 指针 $+/-$ 整数

可以对指针变量 $p$ 进行 `p++`、`p--`、`p+i` 等操作,所得结果也是一个指针,只是指针所指向的内存地址相比于 $p$ 所指的内存地址前进或者后退了 $i$ 个操作数。

2. 指针 $-$ 指针

只有当两个指针都指向同一个数组中的元素时,才允许从一个指针减去另一个指针。减法运算的值是两个指针在内存中的距离(以数组元素的长度为单位),因为减法运算的结果将除以数组元素类型的长度。举个例子:

```cpp
#include "stdio.h"

int main(){
int a[10] = {1,2,3,4,5,6,7,8,9,0};
int sub;
int *p1 = &a[2];
int *p2 = &a[8];

sub = p2-p1;
printf("%d\n",sub);    // 输出结果为 6

return 0;
}
```

 

 

## 逻辑运算

1. 概念:非:not $ ¬$ 与:and $∧$ 或:or $∨$ 异或:xor $⊕$

2. 运算符的优先级:

![](D:\优先级.jpg)

 

## OI历史及规则

### 各项赛事

1. `NOI` 全国青少年信息学奥林匹克竞赛,从 $1984$ 年开始至今
2. `NOIP` 全国青少年信息学奥林匹克联赛,从 $1995$ 年到 $2018$ 年~~(NOIP已死)~~
3. `CSP认证` 从 $2014$ 年开始
4. `CSP-J/S` 非专业级别的能力认证,从 $2019$ 年开始
5. `APIO` 亚洲与太平洋地区信息学奥赛,从 $2007$ 年开始,第一届在澳大利亚举行
6. `IOI` 国际信息学奥林匹克竞赛,从 $1989$ 年在保加利亚开始。中国承办 `IOI` $2000$

### 联赛规则

不用说了,自己访问 www.noi.cn 去看吧!

 

## 计算机基础知识

### 发展史

1. $1946$ 年 $2$ 月,在美国宾夕法尼亚大学诞生了世界上第一台电子计算机`ENIAC`,这台计算机占地 $170$ 平方米,重 $30$ 吨,用了 $18000$ 多个电子管,每秒能进行 $5000$ 次加法运算。

2. 计算机的 $4$ 个发展过程:

>$1.$ 电子管 $1946 - 1958$
>
>$2.$ 晶体管 $1959-1964$
>
>$3.$ 集成电路 $1965-1970$
>
>$4.$ 大规模,超大规模集成电路 $1971 - Now$

3. 冯·诺依曼(美籍匈牙利数学家)思想:计算机由存储器,控制器,运算器,输入设备,输出设备 $5$ 部分组成。

4. 图灵:英国数学家,$1912-1954$

### 系统的基本结构和常识

![](D:\结构.jpg)

2. CPU(中央处理器)的主要指标为主频和字长。

3. CPU是微机的核心部件,是决定微机性能的关键部件。$20$ 世纪 $70$ 年代微型机的CPU问世,微型计算机的核心部件微处理器从`Intel 4004`,`80286`,`80386`,`80486` 发展到 `Pentium II/III` 和 `Pentium 4`,数位从$4$ 位、$8$ 位、$16$ 位、$32$ 位发展到 $64$ 位,主频从几 $MHZ$ 到今天的数 $GHZ$ 以上($1GHZ=1000MHZ$),CPU芯片里集成的晶体管数由 $2$ 万个跃升到 $1000$ 万个以上。

4. 世界上第一个CPU:`Inter 4004`。

5. 进制转换:$1TB=1024GB=1024^2MB=1024^3KB=1024^4B$

6. 各种存储器读取速度比较:`Cache` $>$ `RAM` $>$ `ROM` $>$ 外存 **离CPU越近,速度越快**

7. 总线结构可分为:数据,地址,控制总线。

8. 计算机的软件:

![](D:\软件.png)

9. 计算机的语言:机器语言,汇编语言,高级语言
10. 在高级语言中,编译性语言有 `C/C++`、`Pascal/Object Pascal(Delphi)`等;解释性语言有 `ASP`、`PHP`、`Java`、`JavaScript`、`VBScript`、`Perl`、`Python`、`Ruby` 等。

### 信息编码

1. 字节是存储器系统的最小存取单位。

2. 英文编码:$ASCII$ 码。$ASCII$ 编码是由美国国家标准委员会制定的一种包括数字、字母、通用符号和控制符号在内的字符编码集,全称叫美国国家信息交换标准代码(American Standard Code for Information Interchange)。

![](D:\ASCII 码.png)

3. 汉字编码:国家标准 $GB2312$:包括了 $6763$ 个汉字。

### 原码,反码,补码

1. 原码:原码就是符号位加上真值的绝对值,即用第一位($+ = 0,-=1$)表示符号,其余位表示值。

>$+1 = 0000 0001, -1=1000 0001$

2. 反码:正数的反码是其本身,负数的反码是在其原码的基础上,符号位不变,其余各个位取反。

>$+1 = [0000 0001]_原 = [0000 0001]_反$
>
>$-1 = [1000 0001]_原 = [1111 1110]_反$

3. 正数的补码就是其本身,负数的补码是在其原码的基础上,符号位不变,其余各位取反,最后 $+1$。(即在反码的基础上 $+1$)

>$+1 = [0000 0001]_原 = [0000 0001]_反 = [0000 0001]_补$
>
>$-1 = [1000 0001]_原 = [1111 1110]_反 = [1111 1111]_补$

 

 

# CSP-S 初赛阅读程序与程序填空

## 阅读程序与程序填空

### 常考算法

>约瑟夫环、幻方、求逆序对、归并排序相关操作、求逆序对、快速幂、组合数学、杨辉三角、二进制、搜索(遍历)、$\gcd$ 、$ex\gcd$、最长上升子序列、最长公共子序列、最长公共上升子序列、康拓展开……

其实主要还是以做题为主(模板题)。

![1570240379986](C:\Users\Administrator\AppData\Roaming\Typora\typora-user-images\1570240379986.png)

推荐书籍:《算法竞赛进阶指南》

推荐网站:[牛客网](https://ac.nowcoder.com/acm/skill/noip-tg)

CSP-S 初赛问题求解与选择题

标签:字符串   include   tor   自动分配   杨辉三角   相同   委员会   结构   存储   

原文地址:https://www.cnblogs.com/Believe-R/p/11624317.html

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!