题解:P11600 『Fwb』流星の陨落
前言
把出题人 std 给爆了,请看帖子。
这种做法本质上是对出题人 std 的优化,具有可靠的时间复杂度。
思路
根据题意,我们可以认为
令
我们可以先求出
假设找到一个因子
查表可知,在
时间复杂度为
代码
#include<bits/stdc++.h>
using namespace std;
int n,ans;
vector<int>a;
vector<int>fac;
int main(){
ios::sync_with_stdio(0);
cin.tie(0);cout.tie(0);
cin>>n;
a.push_back(1);
while(n--){
int x; cin>>x;
if(x!=1)a.push_back(x);
}
int t=a[1]-a[0];
for(int i=1;i*i<=t;i++){
if(t%i==0){
fac.push_back(i);
fac.push_back(t/i);
}
}
sort(fac.begin(),fac.end());
for(auto x:fac){
bool f=1;
for(int i=1;i<a.size()&&f;i++){
if((a[i]-a[i-1])%x)f=0;
}
if(f)ans=x;
}
cout<<(a.back()-1)/ans+1<<' '<<ans;
return 0;
}