4311: [GESP202412四级] Recamán
内存限制:256 MB
时间限制:1.000 S
评测方式:文本比较
命题人:
提交:0
解决:0
题目描述
## 题目背景
2024 年 12 月 GESP C++ 四级编程第 1 题
## 题目描述
小杨最近发现了有趣的 $Recamán$ 数列,这个数列是这样生成的:
- 数列的第一项 $a_{1}$ 是 $1$;
- 如果 $a_{k-1} - k$ 是正整数并且没有在数列中出现过,那么数列的第 $k$ 项 $a_{k}$ 为 $a_{k-1} - k$,否则为 $a_{k-1} + k$。
小杨想知道 $Recamán$ 数列的前 $n$ 项从小到大排序后的结果。手动计算非常困难,小杨希望你能帮他解决这个问题。
输入
## 输入格式
第一行,一个正整数 $n$。
输出
## 输出格式
一行,$n$ 个空格分隔的整数,表示 $Recamán$ 数列的前 $n$ 项从小到大排序后的结果。
样例输入 复制
5
样例输出 复制
1 2 3 6 7
提示
## 样例
```input1
5
```
```output1
1 2 3 6 7
```
```input2
8
```
```output2
1 2 3 6 7 12 13 20
```
## 说明/提示
## 样例 1 解释
对于样例1, $n = 5$:
- $a_{1} = 1$
- $a_{1} - 2 = -1$,不是正整数,因此 $a_{2} = a_{1} + 2 = 3$
- $a_{2} - 3 = 0$,不是正整数,因此 $a_{3} = a_{1} + 3 = 6$
- $a_{3} - 4 = 2$,是正整数,且没有在数列中出现过,因此 $a_{4} = 2$
- $a_{4} - 5 = -3$,不是正整数,因此 $a_{5} = a_{4} + 5 = 7$
$a_{1}, a_{2}, a_{3}, a_{4}, a_{5}$ 从小到大排序后的结果为 $1 \;2 \;3 \;6 \;7$。
### 数据范围
对于所有数据点,保证 $1 \leq n \leq 3000$