#F. [GESP202412四级] Recamán

    Type: Default 1000ms 256MiB

[GESP202412四级] Recamán

You cannot submit for this problem because the contest is ended. You can click "Open in Problem Set" to view this problem in normal mode.

题目背景

2024 年 12 月 GESP C++ 四级编程第 1 题

题目描述

小杨最近发现了有趣的 RecamaˊnRecamán 数列,这个数列是这样生成的:

  • 数列的第一项 a1a_{1}11

  • 如果 ak1ka_{k-1} - k 是正整数并且没有在数列中出现过,那么数列的第 kkaka_{k}ak1ka_{k-1} - k,否则为 ak1+ka_{k-1} + k

小杨想知道 RecamaˊnRecamán 数列的前 nn 项从小到大排序后的结果。手动计算非常困难,小杨希望你能帮他解决这个问题。

输入格式

第一行,一个正整数 nn

输出格式

一行,nn 个空格分隔的整数,表示 RecamaˊnRecamán 数列的前 nn 项从小到大排序后的结果。

样例

5
1 2 3 6 7
8
1 2 3 6 7 12 13 20

说明/提示

样例 1 解释

对于样例1, n=5n = 5:

  • a1=1a_{1} = 1

  • a12=1a_{1} - 2 = -1,不是正整数,因此 a2=a1+2=3a_{2} = a_{1} + 2 = 3

  • a23=0a_{2} - 3 = 0,不是正整数,因此 a3=a1+3=6a_{3} = a_{1} + 3 = 6

  • a34=2a_{3} - 4 = 2,是正整数,且没有在数列中出现过,因此 a4=2a_{4} = 2

  • a45=3a_{4} - 5 = -3,不是正整数,因此 a5=a4+5=7a_{5} = a_{4} + 5 = 7

a1,a2,a3,a4,a5a_{1}, a_{2}, a_{3}, a_{4}, a_{5} 从小到大排序后的结果为 1  2  3  6  71 \;2 \;3 \;6 \;7

数据范围

对于所有数据点,保证 1n30001 \leq n \leq 3000

GESP四级编程题练习

Not Claimed
Status
Done
Problem
11
Open Since
2025-3-7 17:00
Deadline
2025-3-22 23:59
Extension
24 hour(s)