标题:1-n之间素数求和超时,怎么优化
只看楼主
f2313660764
Rank: 1
等 级:新手上路
帖 子:20
专家分:0
注 册:2018-11-14
结帖率:14.29%
已结贴  问题点数:10 回复次数:7 
1-n之间素数求和超时,怎么优化
int IsPrime(int num)      //求素数
{
     int i,a=1;
    if(num==1) a=0;
    for(i=2;i<=sqrt(num);i++)
    {
        if(num%i==0)   a=0;
    }
    return a;
}


int SumPrime(int num)        //求1-n之间所有的素数之和
{
    int sum=0,i;
    for(i=1;i<=num;i++)
    {
        if(IsPrime(i)==1) sum=sum+i;
    }
    return sum;
}
搜索更多相关主题的帖子: 素数 超时 int num sum 
2018-11-25 20:01
幻紫灵心
Rank: 11Rank: 11Rank: 11Rank: 11
来 自:山咔咔里面
等 级:贵宾
威 望:53
帖 子:395
专家分:2640
注 册:2018-3-30
得分:3 
除了2,可以直接忽略偶数,减少一半。

saber,别哭.
2018-11-25 20:04
f2313660764
Rank: 1
等 级:新手上路
帖 子:20
专家分:0
注 册:2018-11-14
得分:0 
回复 2楼 幻紫灵心
还是不行
2018-11-25 20:10
幻紫灵心
Rank: 11Rank: 11Rank: 11Rank: 11
来 自:山咔咔里面
等 级:贵宾
威 望:53
帖 子:395
专家分:2640
注 册:2018-3-30
得分:0 
代码贴出来看看,题目地址贴出来看看?这种题要求能有多高?

saber,别哭.
2018-11-25 21:07
zbjzbj
Rank: 12Rank: 12Rank: 12
来 自:郑州
等 级:贵宾
威 望:52
帖 子:620
专家分:3020
注 册:2011-4-22
得分:3 
int IsPrime(int num)      //求素数
{
    if(num==1) return 0;
    for(int i=2;i<=sqrt(num);i++)
    {
        if(num%i==0)   return 0;
    }
    return num;
}
int SumPrime(int num)        //求1-n之间所有的素数之和
{
    int sum=0,i;
    for(i=1;i<=num;i++)
    {
        if(IsPrime(i)==1) sum=sum+i; //sum += IsPrime(i);?
    }
    return sum;
}
2018-11-25 21:13
wlxy_wang
Rank: 5Rank: 5
等 级:职业侠客
威 望:2
帖 子:77
专家分:303
注 册:2018-11-2
得分:3 
1不是素数,主调函数中为什么要从1开始循环呢?
如果不是从1开始循环,被调函数就不需要判断 if(num==1) return 0;
 if(IsPrime(i)==1) 改为 if(IsPrime(i))

int IsPrime(int num)      //求素数
{
      for(int i=2;i<=sqrt(num);i++)
    {
        if(num%i==0)   return 0;
    }
    return num;
}
int SumPrime(int num)        //求1-n之间所有的素数之和
{
    int sum=0,i;
    for(i=1;i<=num;i++)
    {
        if(IsPrime(i)) sum=sum+i; //sum += IsPrime(i);?此句如果用注释后的内容,则又调用了一次函数,大大增加时间开销;
    }
    return sum;
}

[此贴子已经被作者于2018-11-26 16:10编辑过]

2018-11-26 16:04
zbjzbj
Rank: 12Rank: 12Rank: 12
来 自:郑州
等 级:贵宾
威 望:52
帖 子:620
专家分:3020
注 册:2011-4-22
得分:0 
回复 6楼 wlxy_wang
int SumPrime(int num)        //求1-n之间所有的素数之和
{
    int sum=0,i;
    for(i=1;i<=num;i++)
    {
      sum += IsPrime(i);
    }
    return sum;
}
2018-11-26 20:35
kfyniriu
Rank: 6Rank: 6
等 级:侠之大者
威 望:9
帖 子:105
专家分:426
注 册:2018-7-6
得分:3 
int IsPrime(int num)      //求素数
{
    int i;
    if(num==1 || num==2 || num==3)
        return 0;
    else
    {
        for(i=2;i<sqrt(num);i++)
        {
            if(num%i==0)
                return 0;
        }
        return num;
    }
}


int SumPrime(int num)        //求1-n之间所有的素数之和
{
    int sum=0,i;
    for(i=1;i<=num;i++)
    {
        if(IsPrime(i)!=0)
            sum+=i;
    }
    return sum;
}
2018-11-27 16:00



参与讨论请移步原网站贴子:https://bbs.bccn.net/thread-491554-1-1.html




关于我们 | 广告合作 | 编程中国 | 清除Cookies | TOP | 手机版

编程中国 版权所有,并保留所有权利。
Powered by Discuz, Processed in 0.016755 second(s), 8 queries.
Copyright©2004-2025, BCCN.NET, All Rights Reserved