用筛法100以内的素数c语言,用筛法求100之内的素数!!我的程序哪儿错了?麻烦高手看一下!!...

本文介绍了如何利用Eratosthenes筛法在C语言中和汇编语言中实现求素数的方法。在C语言中,通过创建数组并标记合数来找出素数;而在汇编语言中,通过混合编程实现相同功能。文章还提到了在Turbo C环境下编译混合汇编程序的注意事项,包括需要将Lib目录的文件复制到当前目录并使用tcc命令进行编译。
摘要由CSDN通过智能技术生成

该楼层疑似违规已被系统折叠 隐藏此楼查看此楼

Eratosthenes筛法求素数

文章来源:中国学习联盟

我用了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 

#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

if(f[k]!=1)

{

i=k;

break;

}

}

for(i=0;i

if(f[i]==0)

printf("%d,",i);

printf("\n");

}

void asm_method()/*混合汇编的方法*/

{

unsigned f[N+1]={0},i;

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

printf("asm method:\n");

asm mov di,2

asm clc

PROCESS:

asm mov cx,2

PROSON:

asm mov ax,di

asm mov bx,ax

asm mul cx

asm cmp ax,N

asm jae PROSONEND

f[_AX]=1;

asm mov ax,bx

asm inc cx

asm jmp PROSON

PROSONEND:

asm mov si,di

asm inc si

PROSON1:

if(f[_SI]==0)

{

asm je PROSON1END

}

asm inc si

asm jmp PROSON1

PROSON1END:

asm mov di,si

asm cmp di,HALF

asm jae PROEND

asm jmp PROCESS

PROEND:

for(i=0;i

if(f[i]==0)

printf("%d,",i);

return;

}

void main()

{

clrscr();

c_method();

asm_method();

getch();

}

1、资源项目源码均已通过严格测试验证,保证能够正常运行; 2、项目问题、技术讨论,可以给博主私信或留言,博主看到后会第一时间与您进行沟通; 3、本项目比较适合计算机领域相关的毕业设计课题、课程作业等使用,尤其对于人工智能、计算机科学与技术等相关专业,更为适合; 4、下载使用后,可先查看REAdMe.md或论文文件(如有),本项目仅用作交流学习参考,请切勿用于商业用途。 5、资源来自互联网采集,如有侵权,私聊博主删除。 6、可私信博主看论文后选择购买源代码。 1、资源项目源码均已通过严格测试验证,保证能够正常运行; 2、项目问题、技术讨论,可以给博主私信或留言,博主看到后会第一时间与您进行沟通; 3、本项目比较适合计算机领域相关的毕业设计课题、课程作业等使用,尤其对于人工智能、计算机科学与技术等相关专业,更为适合; 4、下载使用后,可先查看REAdMe.md或论文文件(如有),本项目仅用作交流学习参考,请切勿用于商业用途。 5、资源来自互联网采集,如有侵权,私聊博主删除。 6、可私信博主看论文后选择购买源代码。 1、资源项目源码均已通过严格测试验证,保证能够正常运行; 2、项目问题、技术讨论,可以给博主私信或留言,博主看到后会第一时间与您进行沟通; 3、本项目比较适合计算机领域相关的毕业设计课题、课程作业等使用,尤其对于人工智能、计算机科学与技术等相关专业,更为适合; 4、下载使用后,可先查看READme.md或论文文件(如有),本项目仅用作交流学习参考,请切勿用于商业用途。 5、资源来自互联网采集,如有侵权,私聊博主删除。 6、可私信博主看论文后选择购买源代码。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值