玄学模数 · 1e9+7怎么你们了
查看原帖
玄学模数 · 1e9+7怎么你们了
803885
_8008008楼主2024/10/5 20:14

rt
将 modnum改为 3 喜提TLE
我在主函数第9行有优化,按理说只有有解的数对第3个模数会产生时间消耗
而且当 modnum=2 时,最大点 300 ms\le 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;
}
2024/10/5 20:14
加载中...