|
Posted on 2011-09-02 11:12 成幸毅 阅读(455) 评论(0) 编辑 收藏 引用
#include <iostream>
#include <cstdio>
#include <cstring>
#include <cmath>
#include <cstdlib>
#include <algorithm>
using namespace std;
const int maxn = 1100;
typedef __int64 bigint;
bigint gcd(bigint A,bigint B)
data:image/s3,"s3://crabby-images/f86b7/f86b7e502a0580d5e24db72fe38f81dda2bc052d" alt="" data:image/s3,"s3://crabby-images/3ee79/3ee79ec5a9b7f3dd33bbbdc97980715db1aa9f00" alt="" {
while(B)
data:image/s3,"s3://crabby-images/db282/db282e9ea79ad6a7617774c9b676a45b33d46480" alt="" {
bigint C = A%B;
A = B;
B = C;
}
return A;
}
bigint product_mod(bigint A,bigint B,bigint C)
data:image/s3,"s3://crabby-images/f86b7/f86b7e502a0580d5e24db72fe38f81dda2bc052d" alt="" data:image/s3,"s3://crabby-images/3ee79/3ee79ec5a9b7f3dd33bbbdc97980715db1aa9f00" alt="" {
bigint R = 0,D = A;
while(B)
data:image/s3,"s3://crabby-images/db282/db282e9ea79ad6a7617774c9b676a45b33d46480" alt="" {
if(B&1)
data:image/s3,"s3://crabby-images/db282/db282e9ea79ad6a7617774c9b676a45b33d46480" alt="" {
R = (R+D);
if(R>C) R -= C;
}
D += D;
if(D>C) D -= C;
B >>= 1;
}
return R;
}
bigint power_mod(bigint A,bigint B,bigint C)
data:image/s3,"s3://crabby-images/f86b7/f86b7e502a0580d5e24db72fe38f81dda2bc052d" alt="" data:image/s3,"s3://crabby-images/3ee79/3ee79ec5a9b7f3dd33bbbdc97980715db1aa9f00" alt="" {
bigint R = 1,D = A;
while(B)
data:image/s3,"s3://crabby-images/db282/db282e9ea79ad6a7617774c9b676a45b33d46480" alt="" {
if(B&1) R = product_mod(R,D,C);
D = product_mod(D,D,C);
B >>= 1;
}
return R;
}
data:image/s3,"s3://crabby-images/f86b7/f86b7e502a0580d5e24db72fe38f81dda2bc052d" alt="" int pri[] = {2,3,5,7,11,13,17,19,23,29};
bool Miller_Rabin(bigint n)
data:image/s3,"s3://crabby-images/f86b7/f86b7e502a0580d5e24db72fe38f81dda2bc052d" alt="" data:image/s3,"s3://crabby-images/3ee79/3ee79ec5a9b7f3dd33bbbdc97980715db1aa9f00" alt="" {
if(n<2) return false;
if(n==2) return true;
if(!(n&1)) return false;
bigint k = 0,i,j,m,a;
m = n-1;
while(!(m&1)) m = (m>>1),k++;
for(i=0;i<10;i++)
data:image/s3,"s3://crabby-images/db282/db282e9ea79ad6a7617774c9b676a45b33d46480" alt="" {
if(pri[i]>=n) return true;
a = power_mod(pri[i],m,n);
if(a==1) continue;
for(j=0;j<k;j++)
data:image/s3,"s3://crabby-images/db282/db282e9ea79ad6a7617774c9b676a45b33d46480" alt="" {
if(a==n-1) break;
a = product_mod(a,a,n);
}
if(j==k) return false;
}
return true;
}
bigint pollard_rho(bigint C,bigint N)
data:image/s3,"s3://crabby-images/f86b7/f86b7e502a0580d5e24db72fe38f81dda2bc052d" alt="" data:image/s3,"s3://crabby-images/3ee79/3ee79ec5a9b7f3dd33bbbdc97980715db1aa9f00" alt="" {
bigint I,X,Y,K,D;
I = 1;
X=Y=rand()%N;
K = 2;
data:image/s3,"s3://crabby-images/db282/db282e9ea79ad6a7617774c9b676a45b33d46480" alt="" do {
I++;
D = gcd(N+Y-X,N);
if(D>1&&D<N) return D;
if(I==K) Y=X,K<<=1;
X=(product_mod(X,X,N)+N-C)%N;
}while(Y!=X);
return N;
}
bigint allFactor[maxn];
int fn;
void rho(bigint N)
data:image/s3,"s3://crabby-images/f86b7/f86b7e502a0580d5e24db72fe38f81dda2bc052d" alt="" data:image/s3,"s3://crabby-images/3ee79/3ee79ec5a9b7f3dd33bbbdc97980715db1aa9f00" alt="" {
if(Miller_Rabin(N))
data:image/s3,"s3://crabby-images/db282/db282e9ea79ad6a7617774c9b676a45b33d46480" alt="" {
allFactor[++fn]=N;
return ;
}
bigint T = N;
while(T>=N) T = pollard_rho(rand()%(N-1)+1,N);
rho(T);
rho(N/T);
}
int main()
data:image/s3,"s3://crabby-images/f86b7/f86b7e502a0580d5e24db72fe38f81dda2bc052d" alt="" data:image/s3,"s3://crabby-images/3ee79/3ee79ec5a9b7f3dd33bbbdc97980715db1aa9f00" alt="" {
bigint n;
while(true)
data:image/s3,"s3://crabby-images/db282/db282e9ea79ad6a7617774c9b676a45b33d46480" alt="" {
scanf("%I64d",&n);
if(n<=0) break;
if(Miller_Rabin(n)) printf(" %I64d\n",n);
else
data:image/s3,"s3://crabby-images/db282/db282e9ea79ad6a7617774c9b676a45b33d46480" alt="" {
fn=0;
rho(n);
sort(allFactor+1,allFactor+fn+1);
for(int i=1;i<=fn;i++)
data:image/s3,"s3://crabby-images/db282/db282e9ea79ad6a7617774c9b676a45b33d46480" alt="" {
printf(" %I64d\n",allFactor[i]);
}
}
cout<<endl;
}
return 0;
}
data:image/s3,"s3://crabby-images/13de6/13de6130588e8a001331bf125b484ea2f97d951e" alt=""
data:image/s3,"s3://crabby-images/13de6/13de6130588e8a001331bf125b484ea2f97d951e" alt=""
|