NOIP2014 解方程

题目传送门

第一次用秦九韶公式,有点小激动(然而并不)


可以很暴力的从\(1\)\(m\)依次代数。因为用了秦九韶,计算一次是\(O(n)\)的,总复杂度\(O(nm)\)
高精其实没什么必要,我们直接模一个大质数来判断就可以。当它们在模\(p\)意义下为\(0\),就认为原式为\(0\),因为懒,我只用了一个质数。保险起见,建议使用\(\geq2\)个质数
为了读入\(a\),强制使用快读,读入时取模

#include<iostream>
#include<cstdio>
#include<cstring>
#include<algorithm>
#define inf 0x7ffffff
#define gc getchar();
using namespace std;
#define mod 2147483647
#define LL long long
LL read(){LL k=0,f=1;char c=gc;while(!isdigit(c)){if(c=='-')f=-1;c=gc;}while(isdigit(c)){k=(k*10+c-48)%mod;c=gc;}return k*f;}
LL a[110],n,m;
LL calc(int x){  //秦九韶
	LL sum=a[n];
	for(int i=n;i>=1;i--)
	  sum=(sum*x+a[i-1])%mod;
	return sum;
}
int ans[1000010],top;
int main(){
	n=read(),m=read();
	for(int i=0;i<=n;i++) a[i]=read();
	for(int i=1;i<=m;i++){
		if(!calc(i)) ans[++top]=i;
	}
	printf("%d\n",top);
	for(int i=1;i<=top;i++)
	  printf("%d\n",ans[i]);
    return 0;
}
posted @ 2019-11-14 09:45  MorsLin  阅读(115)  评论(0编辑  收藏  举报