一道简单的ACM题,总是超时,高手帮忙看看吧。

http://acm.hrbeu.edu.cn/index.php?act=problem&id=1060我的代码:#include<iostream>#include<... http://acm.hrbeu.edu.cn/index.php?act=problem&id=1060

我的代码:
#include<iostream>
#include<cmath>
using namespace std;
bool isPrime(int n)
{
for(int i=2;i<=sqrt(double(n));i++)
if(n%i==0)
return false;
return true;
}
int main()
{
int n;
while(cin>>n)
{
if(n==0)
break;
for(int i=3;i<=n/2;i++)
if(isPrime(i)&&isPrime(n-i))
{
cout<<n<<" "<<"="<<" "<<i<<" "<<"+"<<" "<<n-i<<endl;
break;
}
}
return 0;
}
展开
 我来答
冰火梦幻
2011-06-04 · TA获得超过2308个赞
知道小有建树答主
回答量:1095
采纳率:57%
帮助的人:418万
展开全部
1.事先将1000000以内的所有素数算出来,放到数组vector<int>Prime里。不要每次都重复运算。
2.之后暴搜就行了,也就是for(int i = 3; i <= n/2; i++)改成for(int i = 0; i < Prime.size() && Prime[i] <= n/2; i++)。
推荐律师服务: 若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询

为你推荐:

下载百度知道APP,抢鲜体验
使用百度知道APP,立即抢鲜体验。你的手机镜头里或许有别人想知道的答案。
扫描二维码下载
×

类别

我们会通过消息、邮箱等方式尽快将举报结果通知您。

说明

0/200

提交
取消

辅 助

模 式