专栏文章

题解:P12408 始终

P12408题解参与者 3已保存评论 2

文章操作

快速查看文章及其快照的属性,并进行相关操作。

当前评论
2 条
当前快照
1 份
快照标识符
@mipf2j1n
此快照首次捕获于
2025/12/03 10:57
3 个月前
此快照最后确认于
2025/12/03 10:57
3 个月前
查看原文
本题题意非常清楚,在此不赘述了。

思路分析

n=2n = 2 时,设序列为 {a1,a2}\{a_1,a_2\},则应使 lcm(a1,a2)=lcm(a1a2)\text{lcm}(a_1,a_2)=\text{lcm}(|a_1 - a_2|)。由于 a1a2a_1\neq a_21ai1061\leq a_i\leq10^6,经过分析发现不存在满足条件的 a1a_1a2a_2,所以输出 -1。样例也体现了这个结论。
题目背景中“以我为始,以我为终”提示答案或许与循环有关。事实也确实如此。
在较小的正整数中,1212 的因数较多。可以尝试构造最小公倍数为 1212 的解。经过尝试,发现 {2,6,12,6}\{2,6,12,6\} 符合要求。循环输出此序列即可。

Code

CPP
#include<bits/stdc++.h>

using namespace std;

constexpr int num[]={2,6,12,6};

int main(){
	ios::sync_with_stdio(false),
	cin.tie(nullptr),cout.tie(nullptr);
	
	int n;cin>>n;
	
	if(n==2)cout<<"-1";
	else for(int i=1;i<=n;++i)cout<<num[i&3]<<' '; //i & 3 == i % 4
	return 0;
}

评论

2 条评论,欢迎与作者交流。

正在加载评论...