-
讨论 (1)
最近创建的讨论
-
0评论
wating
- 数字替换2024.12GESP3级T1
- @ 2026-04-26 19:10:24
-
-
贡献 (1)
-
递交 (59)
最近递交
状态 题目 递交者 时间 内存 语言 递交时间 (自测) P2881 时间跨越2025.3GESP2级T2 (隐藏) 202603zj18王松博 (王松博) 3ms 512.0 KiB C++ 2026-05-01 14:53:15 (自测) P2881 时间跨越2025.3GESP2级T2 (隐藏) 202603zj18王松博 (王松博) 0ms 0 Bytes C++ 2026-05-01 14:52:41 (自测) P1029 A1-4 循环结构练习:今年过去了多少天 (隐藏) 202603zj18王松博 (王松博) 6ms 512.0 KiB C++ 2026-05-01 14:38:28 P1000 大象喝水 (隐藏) 202603zj18王松博 (王松博) 0ms 0 Bytes C 2026-04-26 23:38:10 P1004 成绩表 202603zj18王松博 (王松博) 9ms 480.0 KiB C++ 2026-04-26 20:27:15 P1002 摘葡萄 (隐藏) 202603zj18王松博 (王松博) 6ms 532.0 KiB C++ 2026-04-26 20:10:16 P3052 凯撒密码 GESP202603 三级T2 202603zj18王松博 (王松博) 17ms 532.0 KiB C++ 2026-04-26 19:39:37 P3012 密码强度202512GESP3级T1 202603zj18王松博 (王松博) 18ms 532.0 KiB C++ 2026-04-26 19:36:15 P2883 词频统计2025.3GESP3级T2 (隐藏) 202603zj18王松博 (王松博) 18ms 532.0 KiB C++ 2026-04-26 19:32:34 P2882 2025 2025.3GESP3级T1 (隐藏) 202603zj18王松博 (王松博) 0ms 0 Bytes C 2026-04-26 19:26:04
个人简介
哪位大神帮我解下这道题
洛谷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\)。