Chinaunix首页 | 论坛 | 博客
  • 博客访问: 388876
  • 博文数量: 55
  • 博客积分: 1907
  • 博客等级: 上尉
  • 技术积分: 869
  • 用 户 组: 普通用户
  • 注册时间: 2010-11-04 19:30
文章分类

全部博文(55)

文章存档

2011年(32)

2010年(23)

分类: C/C++

2010-11-28 19:10:19

/*
 * 用埃拉托色尼(Eratosthense)算法计算质数.
 * Sieve of Dratosthense -- compute prime numbers using an array
 * 2010-11-20
 */

#include <stdlib.h>

#define SIZE    1000

#define TRUE    1
#define FALSE    1000


int main()
{
    char sieve[ SIZE ];
    char *sp;
    int number;

    /* 将sieve[ SIZE ]初始化为 TRUE */
    for( sp = sieve; sp < &sieve[ SIZE ]; sp++ )
        *sp = TRUE;

    for( number = 3; ; number += 2 )
    {
        sp = &sieve[ 0 ] + ( number - 3 ) / 2;
        if ( sp > &sieve[ SIZE ] )
            break;

        while( sp += number, sp < &sieve[ SIZE ] )
            *sp = FALSE;
    }

    printf( "2\n" );

    for( number = 3, sp = &sieve[ SIZE ];
        sp < &sieve[ SIZE ];
        number += 2, sp++ )
    {
        if( *sp )
            printf( "%d\n", number );
    }

    return EXIT_SUCCESS;
}


阅读(1283) | 评论(0) | 转发(0) |
0

上一篇:指针之6.3

下一篇:指针之6.5

给主人留下些什么吧!~~