数素数
题目描述
令Pi表示第i个素数。现任给两个正整数M <= N <= 10000,请输出PM到PN的所有素数。
输入描述
输入在一行中给出M和N,其间以空格分隔。
输出描述
输出从PM到PN的所有素数,每10个数字占1行,其间以空格分隔,但行末不得有多余空格。
输入例子
5 27
输出例子
11 13 17 19 23 29 31 37 41 43
47 53 59 61 67 71 73 79 83 89
97 101 103
解题思路:
- 输入M、N,创建一个动态数组,分配(N-M+1)大小的数组
- 循环判断素数,用k=0表示不是素数,k=1表示素数
- 每确定一个素数就使用 l 计数一次,用来确定这是第几个素数,当M<=l<=N时,将该范围的素数存入数组中
- 遍历数组输出,初始化k=0,并用k计数输出的个数,当k能被10整除就换行
正解:
#include<stdio.h> #include<stdlib.h> #include<math.h> int main(){ int M,N,k,*p; int i=2,l=1; scanf("%d%d",&M,&N); p = (int*)malloc((N-M+1)*(sizeof(int))); while(l<=N){ k = 1; for(int j=2;j<=sqrt(i);j++){ if(i%j==0) k=0; } if(k==1){ //是素数 if(l>=M&&l<=N) p[l-M] = i; l++; } i++; } k=0; for(i=0;i<N-M;i++){ printf("%d ",p[i]); k++; if(k%10 == 0) printf("\n"); } printf("%d",p[N-M]); return 0; }
__EOF__

本文作者:techgy
本文链接:https://www.cnblogs.com/techgy/p/14352383.html
关于博主:I am a good person
版权声明:本博客所有文章除特别声明外,均采用 BY-NC-SA 许可协议。转载请注明出处!
声援博主:如果您觉得文章对您有帮助,可以点击文章右下角【推荐】一下。您的鼓励是博主的最大动力!
本文链接:https://www.cnblogs.com/techgy/p/14352383.html
关于博主:I am a good person
版权声明:本博客所有文章除特别声明外,均采用 BY-NC-SA 许可协议。转载请注明出处!
声援博主:如果您觉得文章对您有帮助,可以点击文章右下角【推荐】一下。您的鼓励是博主的最大动力!
【推荐】国内首个AI IDE,深度理解中文开发场景,立即下载体验Trae
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· 从 HTTP 原因短语缺失研究 HTTP/2 和 HTTP/3 的设计差异
· AI与.NET技术实操系列:向量存储与相似性搜索在 .NET 中的实现
· 基于Microsoft.Extensions.AI核心库实现RAG应用
· Linux系列:如何用heaptrack跟踪.NET程序的非托管内存泄露
· 开发者必知的日志记录最佳实践
· TypeScript + Deepseek 打造卜卦网站:技术与玄学的结合
· Manus的开源复刻OpenManus初探
· AI 智能体引爆开源社区「GitHub 热点速览」
· 从HTTP原因短语缺失研究HTTP/2和HTTP/3的设计差异
· 三行代码完成国际化适配,妙~啊~