rt
将 modnum改为 3 喜提TLE
我在主函数第9行有优化,按理说只有有解的数对第3个模数会产生时间消耗
而且当 modnum=2 时,最大点 ≤300 ms AC,改为 3 就 T 了
#include<iostream>
#define int long long
#define getchar() getchar_unlocked()
using namespace std;
const int maxn=10005;
const int modnum=2;
const int mod[6]={0,998244353,77777647,1000000007,80001083,75001051};
char s[maxn];
int n,m;
int a[maxn][6];
inline void read(int x){
int k[6]={0},f=1;
char c=getchar();
while(c<'0'||c>'9'){
if(c=='-')f=-1;
c=getchar();
}
while(c>='0'&&c<='9'){
for(int i=1;i<=modnum;i++){
k[i]=k[i]*10+c-'0';
k[i]%=mod[i];
}
c=getchar();
}
for(int i=1;i<=modnum;i++){
a[x][i]=f*k[i];
}
}
inline bool calc(int x,int y){
int sum=0;
for(int i=n;i>=1;i--){
sum=((a[i][y]+sum+mod[y])*x)%mod[y];
}
sum=(sum+a[0][y]+mod[y])%mod[y];
return sum==0;
}
int ans[maxn],cnt;
signed main(){
scanf("%lld%lld",&n,&m);
for(int i=0;i<=n;i++){
read(i);
}
for(int i=1;i<=m;i++){
bool check=true;
for(int j=1;j<=modnum;j++){
check&=calc(i,j);
if(!check)break;
}
if(check)ans[++cnt]=i;
}
printf("%lld\n",cnt);
for(int i=1;i<=cnt;i++){
printf("%lld\n",ans[i]);
}
return 0;
}