记录编号 |
346272 |
评测结果 |
AAAAAAAAAA |
题目名称 |
[NOIP 2014]解方程 |
最终得分 |
100 |
用户昵称 |
Go灬Fire |
是否通过 |
通过 |
代码语言 |
C++ |
运行时间 |
2.610 s |
提交时间 |
2016-11-12 07:23:37 |
内存使用 |
38.05 MiB |
显示代码纯文本
- #include<cstdio>
- #include<algorithm>
- #include<cstring>
- #include<ctime>
- #include<iostream>
- #include<cmath>
- using namespace std;
- #define LL long long
- #define Inf 1e9+7
- const int maxn=1000000+10;
- const int Mod[20]={0,12341,18951,14441,12345,13331,16367};
- int n,m,ans[maxn],a[8][maxn];
- void Init();
- int MOD(char s[],int mod){
- int len=strlen(s);
- int x=0;
- if(s[0]=='-'){
- for(int i=1;i<len;i++)x=x*10+s[i]-48,x%=mod;
- return -1*x;
- }
- else {
- for(int i=0;i<len;i++)x=x*10+s[i]-48,x%=mod;
- return x;
- }
- }
- bool Judge(int x,int y){
- int date=a[x][n];//秦九韶判断是否最后值为0,取模运算只对除法无效
- for(int i=n;i>=1;i--){
- date=((date*y)%Mod[x]+a[x][i-1])%Mod[x];
- }
- return date==0 ? true : false;
- }
- bool flag[8][maxn];
- void Get(){
- for(int i=1;i<=6;i++)
- for(int j=1;j<=Mod[i];j++)
- flag[i][j]=Judge(i,j);
- }
- int main(){
- freopen("equationa.in","r",stdin);
- freopen("equationa.out","w",stdout);
- Init();
- //printf("Timeused=%.3lf",(double)clock()/CLOCKS_PER_SEC);
- //for(;;);
- getchar();getchar();
- return 0;
- }
- void Init(){
- scanf("%d%d",&n,&m);
- for(int i=0;i<=n;i++){
- char s[maxn];scanf("%s",s);
- for(int j=1;j<=6;j++){
- a[j][i]=MOD(s,Mod[j]);
- }
- }
- Get();
- int num=0;
- for(int i=1;i<=m;i++){
- bool ok=0;
- for(int j=1;j<=6;j++){
- if(!flag[j][i%Mod[j]]){ok=1;break;}
- }
- if(!ok)ans[++num]=i;
- }
- printf("%d\n",num);
- for(int i=1;i<=num;i++)printf("%d\n",ans[i]);
- }
- /*
- 2 10
- 1 -2 1
- ans 1 1
- */
- /*
- 2 10
- 2 -3 1
- ans 2 1 2
- */
- /*
- 2 10
- 1 3 2
- ans 0
- */