POJ
来源:互联网 发布:刚出土的兵马俑知乎 编辑:程序博客网 时间:2024/06/07 01:06
给定一个大数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");
}
}
}
- POJ
- poj
- POJ
- POJ
- poj
- poj
- POJ
- POJ
- poj
- POJ
- POJ
- POJ
- POJ
- POJ
- POJ
- POJ
- POJ
- POJ
- java动态代理处理事务
- leeetcode15. 3Sum
- AdvancedInstaller设置当用户选择中文路径时弹窗警告
- 经典笔试编程题--Java实现
- 定时器工具类
- POJ
- jquery获取当前页面的URL信息
- 二叉树的前中后遍历推导
- 第九篇 蓝牙配对
- 与dalao学校的联shou考wan(11.2)(dp+乱搞+树形dp+期望)
- 打包的msi,在别人电脑找不到网络位置、MFC RC 4005: IDCANCEL:redefinition
- ssm报错之 org.apache.ibatis.binding.BindingException: Invalid bound statement (not found)
- es6从入门到放弃之let,const,块级作用域
- MySQL密码错误,忘记密码无法进入服务,修改密码