素数的筛选找法

简介: 素数的筛选找法
/*
   素数的筛选找法
  coder:qpz
  time:2014-12-15
*/ 
#include <stdio.h>
#include <stdlib.h>
void Init(char *a,int n)
{
         inti;
         for(i=0;i<n;i++){
                   if(i<2){
                            a[i]=0;
                   }else{
                            a[i]=1;
                   }
         }
}
void findit(char *a,int n);
int main(void)
{
         intn;
         scanf("%d",&n);
         char*a=(char *)malloc((n+1)*sizeof(char));
         Init(a,n);
         findit(a,n);
         return0;
}
void findit(char *a,int n)
{
         inti,j;
         intcnt;
         printf("%d以内的素数有:",n);
         for(i=4;i<=n;i++){
                   for(j=2;j*j<i;j++){
                            if(a[j]){
                               if(i%j == 0){
                                 a[i]=0;
                                 break;
                               }
                            }
                   }/*endj*/
         }/*endi*/
         for(i=0,cnt=0;i<=n;i++){
                   if(a[i]){
                   if(cnt%10== 0) {
                            putchar('\n');
                   }
                            printf("%5d",i);
                            cnt++;
                   }
         }
}


相关文章
|
5月前
求出这个数列的前20项之和
求出这个数列的前20项之和。
46 11
|
5月前
|
存储 C语言 Python
有一分数序列:2/1,3/2,5/3,8/5,13/8,21/13…求出这个数列的前20项之和。
有一分数序列:2/1,3/2,5/3,8/5,13/8,21/13…求出这个数列的前20项之和。
683 4
|
9月前
等差素数列
等差素数列
42 0
|
9月前
|
C++
『C/C++』Eg1:数列的前20项之和
『C/C++』Eg1:数列的前20项之和
判断10-105之间有多少个素数,并输出所有素数。【素数又称为质数,定义为在大于1的 自然数中,除了1和它本身以外不再有其他因数的数
判断10-105之间有多少个素数,并输出所有素数。【素数又称为质数,定义为在大于1的 自然数中,除了1和它本身以外不再有其他因数的数
120 0
|
存储 人工智能 算法
区间分组的解法
区间分组的解法
求自定义范围内的素数(质数)
判定数字是质数需要循环判断 因此需要定义(flag)用于记录循环的结果 结果如图
98 0
求自定义范围内的素数(质数)
7-176 求n以内最大的k个素数以及它们的和 (20 分)
7-176 求n以内最大的k个素数以及它们的和 (20 分)
440 0