线性筛法--------2013年1月2日

简介:
   问题描述:在做筛法求质数的问题时,在删除非质数的数据时,有很多是重复删除的。例如,如果有一个数是3x7x17x23,那么在删除3的倍数时会删除它,删除7,17与23的倍数时也都会删除它。请写一个程序,在删除非质数时"绝对"不做重复的工作。
         思路:有一个因式分解定理:任何一个合数都可以分解成若干个质数相乘的形式。那么,num一定可以分解成p的i次方乘以q的形式(p,q是质数且p<q)。所以,需要去除的数就变成了p的2次方,p的3次方,p的4次方......以及p的i次方乘以q,i=1,2,3.......p和q的取值是从小到大的没有被去除的数,所以很容易就可以写出如下的程序。
 1 #include <stdio.h>
 2 #define MAX 1000
 3 #define null1 0
 4 #define NEXT(x)  x=next[x]
 5 #define REMOVE(x) {   previous[next[x]]=previous[x];   \
 6                       next[previous[x]]=next[x];       \
 7                   }
 8 
 9 #define INITIAL(n)  { unsigned long i;                    \
10                       for(i=2;i<=n;i++)                   \
11                           previous[i]=i-1,next[i]=i+1;    \
12                       previous[2]=next[n]=null1;           \
13                     }
14 
15 int main()
16 {
17     unsigned long previous[MAX+1]={0};
18     unsigned long next[MAX+1]={0};
19     unsigned long prime,fact,i,mult;
20     unsigned long n;
21     unsigned long count=0;
22     
23     scanf("%lu",&n);
24 
25     INITIAL(n); //initial the array
26 
27     for(prime=2;prime*prime<=n;NEXT(prime))
28     {
29         for(fact=prime;prime*fact<=n;NEXT(fact)) 
30         {
31             for(mult=prime*fact;mult<=n;mult*=prime) 
32                 REMOVE(mult);
33         }
34     }
35     for(i=2;i!=null1;NEXT(i))
36         printf("%lu ",i),count++;
37     printf("\nThe sum of the prime numbers is %lu\n",count);
38 }

 
相关文章
|
存储 SQL Oracle
PL/SQL存储过程的使用
PL/SQL存储过程的使用
325 1
|
数据采集 运维 算法
Best Matching Unit,简称 BMU
最佳匹配单元(Best Matching Unit,简称 BMU)是自组织映射(Self-Organizing Maps,简称 SOM)算法中的一个重要概念。在 SOM 网络中,每个神经元都对应一个权重向量,表示该神经元对输入特征的响应。BMU 是指在 SOM 网络中与输入数据最相似的神经元,即具有与输入数据最接近的权重向量。在训练过程中
536 3
|
存储 Oracle Java
多线程进阶学习04------Synchronized详解(1)
多线程进阶学习04------Synchronized详解
163 0
|
存储 JavaScript 前端开发
JavaScript对象
JavaScript对象
|
C# 编译器 索引
带你读《C# 7.0本质论》之三:更多数据类型
作为历年来深受各层次开发人员欢迎的C#权威指南,本书讨论了从C#3.0到7.0的最重要的C#特性,强调了现代编程模式,可帮助读者编写简洁、强大、健壮、安全和易于维护的C#代码。世界级C#专家Mark Michaelis对语言进行了全面而深入的探讨,提供了对关键C#7.0增强、C#7.0和.NET Core/.NET Standard的配合使用以及跨平台编译的专业论述。
|
4天前
|
弹性计算 关系型数据库 微服务
基于 Docker 与 Kubernetes(K3s)的微服务:阿里云生产环境扩容实践
在微服务架构中,如何实现“稳定扩容”与“成本可控”是企业面临的核心挑战。本文结合 Python FastAPI 微服务实战,详解如何基于阿里云基础设施,利用 Docker 封装服务、K3s 实现容器编排,构建生产级微服务架构。内容涵盖容器构建、集群部署、自动扩缩容、可观测性等关键环节,适配阿里云资源特性与服务生态,助力企业打造低成本、高可靠、易扩展的微服务解决方案。
1106 0
|
3天前
|
机器学习/深度学习 人工智能 前端开发
通义DeepResearch全面开源!同步分享可落地的高阶Agent构建方法论
通义研究团队开源发布通义 DeepResearch —— 首个在性能上可与 OpenAI DeepResearch 相媲美、并在多项权威基准测试中取得领先表现的全开源 Web Agent。
533 10
|
13天前
|
人工智能 运维 安全
|
12天前
|
人工智能 测试技术 API
智能体(AI Agent)搭建全攻略:从概念到实践的终极指南
在人工智能浪潮中,智能体(AI Agent)正成为变革性技术。它们具备自主决策、环境感知、任务执行等能力,广泛应用于日常任务与商业流程。本文详解智能体概念、架构及七步搭建指南,助你打造专属智能体,迎接智能自动化新时代。
|
4天前
|
弹性计算 Kubernetes jenkins
如何在 ECS/EKS 集群中有效使用 Jenkins
本文探讨了如何将 Jenkins 与 AWS ECS 和 EKS 集群集成,以构建高效、灵活且具备自动扩缩容能力的 CI/CD 流水线,提升软件交付效率并优化资源成本。
302 0

热门文章

最新文章