HOJ1356素数判断,求大神看看我的code为什么超时?

码蹄疾 2012-07-27 10:54:22
#include<iostream>
#include <stdio.h>
#include <stdlib.h>
#include<cmath>
using namespace std;
long long judge(long long a, long long b, long long n) //求(a^b) mod n
{
long long d=1,t=a;
while (b>0)
{
if (t==1) return d ;
if (b%2==1) d=d*t%n;
b/=2;
t=t*t%n;
}
return d;
}
int prime(long long n)
{
long long a;
a=rand()%(n-1)+1;
if(judge(a,n-1,n)%n!=1) return 0;
else return 1;
}
int main()
{
long long n;
int t,flag;
while(cin >> n)
{
flag=1;//1为素数
if(n<=1) flag=0;
else if(n==2||n==3) flag=1;
else
{
t=3;
while(t--&&flag)
{
if(!prime(n))
{
flag=0;
}
}
}
if(flag) cout << "Yes" << endl;
else cout << "No" << endl;
}
return 0;
}


...全文
126 6 打赏 收藏 转发到动态 举报
写回复
用AI写文章
6 条回复
切换为时间正序
请发表友善的回复…
发表回复
码蹄疾 2012-07-27
  • 打赏
  • 举报
回复
费马小定理?我上面的代码就是用这个啊!但是提交还是超时,不知道为什么!
hen_hao_ji 2012-07-27
  • 打赏
  • 举报
回复
对不起搞错了,2^31这么大的数,只能用概率判素模型
http://www.baidu.com/s?wd=hoj+1356&opt-webpage=on&ie=gbk
码蹄疾 2012-07-27
  • 打赏
  • 举报
回复
不是杭电OJ啊,亲!!是哈工大的,HOJ!
hen_hao_ji 2012-07-27
  • 打赏
  • 举报
回复

64,639

社区成员

发帖
与我相关
我的任务
社区描述
C++ 语言相关问题讨论,技术干货分享,前沿动态等
c++ 技术论坛(原bbs)
社区管理员
  • C++ 语言社区
  • encoderlee
  • paschen
加入社区
  • 近7日
  • 近30日
  • 至今
社区公告
  1. 请不要发布与C++技术无关的贴子
  2. 请不要发布与技术无关的招聘、广告的帖子
  3. 请尽可能的描述清楚你的问题,如果涉及到代码请尽可能的格式化一下

试试用AI创作助手写篇文章吧