考试网 >> IT认证 >> 等级 >> 等级动态 >> Eratosthenes筛法求素数

Eratosthenes筛法求素数

发布时间:2006-07-25 12:00     点击:
分页:[1] 2 3  下一页

     我用了c的方法和在tc下混合编程的方法,如果用win-tc就可以直接编译此程序,如果是用tc2.0就必须用tcc编辑器自己编译。或许很多人用tc嵌入汇编的时候会觉得编译不通过,编译的时候需要将tc所在目录里的Lib目录里的所有文件复制到tc当前目录下,然后用在当前目录用 tcc -Iinclude -Llib 文件名字既可。比如以下程序在文件su.c中,那么你只需要在tc目录里用tcc -Iinclude -Llib su的命令既可编译此程序。当然有win-tc更为方便,直接编译就可以了。  

/*  

Description:  

Eratosthenes筛法  

创建一个数组,以下面的方式将某些位置以1标记:从位置2开始,将所有2的倍数的位置  

标记为1,然后对2之后的素数3进行同样的操作这样就可以找到3之后未被标记的5,  

然后再将所有5的倍数记1,如此重复便可以找到数组中的所有素数。  

Author:跳蚤侦探  

Date: 22/08/2004  

Copyright:www.8623.com  

*/  

#include <dos.h>  

#define N 100  

#define HALF N/2  

void c_method()/*c语言的方法*/  

{  

int f[N+1]={0},i,j,k;  

printf("c method:\n");  

f[0]=f[1]=1;  

i=2;  

while(i<=N/2)  

{  

 j=2;  

 while(1)  

 {  

 f[j*i]=1;  

 j++;  

 if((j*i)>=N)  

  break;  

 }  

 for(k=i+1;k<N;k++)  

 if(f[k]!=1)  

  {  
分页:[1] 2 3  下一页
版权申明:未经书面授权请勿转载本站信息!!作品版权归所属媒体与作者所有!!
发表评论: 匿名发表 用户名: 查看评论
您将承担一切因您的行为、言论而直接或间接导致的民事或刑事法律责任
留言板管理人员有权保留或删除其管辖留言中的任意内容
本站提醒:不要进行人身攻击。谢谢配合。
在本站搜索相关信息
2003-2005 Ksw123.com All Rights Reserved. - TOP
Copyright © 2006 Ksw123.com. All rights reserved.中国考题网 版权所有