-
讨论 (0)
这个用户还没有发布过讨论 -
贡献 (0)
啊哦,这个用户还没贡献过题目和题解~ -
递交 (0)
最近递交
状态 题目 递交者 时间 内存 语言 递交时间 P3068 翻滚的长方体 202602saccc三级T6 王松博 17ms 532.0 KiB C++ 2026-06-27 18:21:26 P3068 翻滚的长方体 202602saccc三级T6 王松博 0ms 0 Bytes C 2026-06-27 18:20:06 P3066 真人秀 202602saccc三级T4 王松博 52ms 568.0 KiB C++ 2026-06-27 18:05:28 P3065 下棋 202602saccc三级T3 王松博 18ms 532.0 KiB C++ 2026-06-27 17:53:47 P3065 下棋 202602saccc三级T3 王松博 0ms 0 Bytes C++ 2026-06-27 17:53:20 P3063 算式 202602saccc三级T1 王松博 17ms 532.0 KiB C++ 2026-06-27 17:42:28 * 王松博 152ms 608.0 KiB C++ 2026-06-26 22:03:53 * 王松博 17ms 532.0 KiB C++ 2026-06-26 21:55:17 * 王松博 18ms 532.0 KiB C++ 2026-06-26 21:43:11 * 王松博 ≥2022ms ≥608.0 KiB C++ 2026-06-26 21:24:24
个人简介
哪位大神帮我解下这道题
洛谷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\)。