-
讨论 (0)
这个用户还没有发布过讨论 -
贡献 (0)
啊哦,这个用户还没贡献过题目和题解~ -
递交 (0)
最近递交
状态 题目 递交者 时间 内存 语言 递交时间 (自测) * 王松博 4ms 472.0 KiB C++ 2026-03-28 16:48:42 (自测) * 王松博 2ms 532.0 KiB C++ 2026-03-28 16:24:15 (自测) * 王松博 0ms 0 Bytes C 2026-03-28 16:23:57 (自测) * 王松博 0ms 0 Bytes C++ 2026-03-21 15:58:21 (自测) * 王松博 0ms 0 Bytes C++ 2026-03-21 15:58:14 (自测) * 王松博 0ms 0 Bytes C++ 2026-03-15 19:42:53 (自测) * 王松博 0ms 0 Bytes C++ 2026-03-15 19:41:38 (自测) * 王松博 0ms 0 Bytes C++ 2026-03-15 19:41:38 (自测) * 王松博 0ms 0 Bytes C++ 2026-03-15 19:41:37 (自测) * 王松博 0ms 0 Bytes C++ 2026-03-15 19:41:37
个人简介
哪位大神帮我解下这道题
洛谷B4068 [GESP202412 四级] Recamán
题目背景
对应的选择、判断题:https://ti.luogu.com.cn/problemset/1168
题目描述
小杨最近发现了有趣的 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\) 项从小到大排序后的结果。
输入输出样例 #1
输入 #1
5
输出 #1
1 2 3 6 7
输入输出样例 #2
输入 #2
8
输出 #2
1 2 3 6 7 12 13 20
说明/提示
样例解释
对于样例 1,\(n=5\):
- \(a_1=1\);
- \(a_1-2=-1\),不是正整数,因此 \(a_2=a_1+2=3\);
- \(a_2-3=0\),不是正整数,因此 \(a_3=a_2+3=6\);
- \(a_3-4=2\),是正整数,且没有在数列中出现过,因此 \(a_4=a_3-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\le n\le 3\, 000\)。