国产探花免费观看_亚洲丰满少妇自慰呻吟_97日韩有码在线_资源在线日韩欧美_一区二区精品毛片,辰东完美世界有声小说,欢乐颂第一季,yy玄幻小说排行榜完本

首頁 > 學院 > 開發設計 > 正文

Eratosthenes篩法求素數

2019-11-17 05:41:05
字體:
來源:轉載
供稿:網友
 我用了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;
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)
  {
  i=k;
  break;
  }
}
  for(i=0;i<N;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<N;i++)
   if(f[i]==0)
    printf("%d,",i);
 return;
}void main()
{
 clrscr();
 c_method();
 asm_method();
 getch();
}

發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
主站蜘蛛池模板: 特克斯县| 阳信县| 鄢陵县| 泸州市| 定日县| 安庆市| 襄汾县| 海宁市| 湖南省| 霍山县| 景谷| 白水县| 理塘县| 三门县| 哈巴河县| 边坝县| 汪清县| 昭觉县| SHOW| 扎兰屯市| 姚安县| 潜山县| 松阳县| 延津县| 淳化县| 冕宁县| 石阡县| 茌平县| 开原市| 贺兰县| 曲靖市| 旺苍县| 南雄市| 松原市| 贡嘎县| 石楼县| 手游| 合作市| 连南| 汪清县| 山阳县|