POJ - 2635 The Embarrassed Cryptographer 同余模运算+十进制转化为千进制!

给定一个大数K,

K是两个大素数的乘积的值。

再给定一个int内的数L

问这两个大素数中最小的一个是否小于L,

如果小于则输出这个素数。

同余模运算+十进制转化为千进制

我wa和T了14次,因为打表打的太多了,超时了。。

我的具体做法是

假如123456和1234567

千进制数组表示方法分别是

[0][123][456]

[1][234][567]

#include <stdio.h>
#include <string.h>
#define N 1000050
int f[N];int t;
int fp[N];
char a[10005];
int op[1005];
int num=0;
void isprime(){
	memset(f,0,sizeof(f));
	f[1]=1;
	for(int i=2;i<N-5;i++){
		if(!f[i]){
			fp[num++]=i;
			for(int j=i+i;j<N-5;j+=i){
				f[j]=1;
			}
		}
	}
}
int main(){
	memset(a,0,sizeof(a));
	isprime();
	while(~scanf("%s",a)){
		scanf("%d",&t);
		if(!strcmp(a,"0")&&t==0) break;
		int len=strlen(a);
		int k=len%3;
		memset(op,0,sizeof(op));
		if(k==1) op[0]=a[0]-'0';
		else if(k==2) op[0]=(a[0]-'0')*10+a[1]-'0';
		else op[0]=0;
		int ct=k;
		for(int i=1;i<=len/3;i++){
			op[i]=(a[ct]-'0')*100;ct++;
			op[i]+=(a[ct]-'0')*10;ct++;
			op[i]+=(a[ct]-'0')*1;ct++;?
		}
		// for(int i=0;i<=len/3;i++){
		// printf("^^^^^^^^^^^^%d\n",op[i]);
		// }
		int i,j;
		for(j=0;j<num;j++){
			int temp=0;
			if(fp[j]>=t) break;
			for(i=0;i<=len/3;i++){
				temp=(temp*1000+op[i])%fp[j];
			}
			if(temp==0) break;
		}
		if(fp[j]<t&&j!=num){
			printf("BAD %d\n",fp[j]);
		}else{
			printf("GOOD\n");
		}
	}
}

 

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值