<?xml version="1.0"?>
<feed xmlns="http://www.w3.org/2005/Atom" xml:lang="zh-Hans-CN">
	<id>https://wiki.riguz.com/index.php?action=history&amp;feed=atom&amp;title=Eratosthenes%E7%AD%9B%E6%B3%95</id>
	<title>Eratosthenes筛法 - 版本历史</title>
	<link rel="self" type="application/atom+xml" href="https://wiki.riguz.com/index.php?action=history&amp;feed=atom&amp;title=Eratosthenes%E7%AD%9B%E6%B3%95"/>
	<link rel="alternate" type="text/html" href="https://wiki.riguz.com/index.php?title=Eratosthenes%E7%AD%9B%E6%B3%95&amp;action=history"/>
	<updated>2026-06-02T18:50:46Z</updated>
	<subtitle>本wiki上该页面的版本历史</subtitle>
	<generator>MediaWiki 1.42.3</generator>
	<entry>
		<id>https://wiki.riguz.com/index.php?title=Eratosthenes%E7%AD%9B%E6%B3%95&amp;diff=1213&amp;oldid=prev</id>
		<title>imported&gt;Soleverlee：​以“埃拉托色尼选筛法(the Sieve of Eratosthenes)简称埃氏筛法，是古希腊数学家埃拉托色尼(Eratosthenes 274B.C.～194B.C.)提出的一种筛选法...”为内容创建页面</title>
		<link rel="alternate" type="text/html" href="https://wiki.riguz.com/index.php?title=Eratosthenes%E7%AD%9B%E6%B3%95&amp;diff=1213&amp;oldid=prev"/>
		<updated>2015-05-22T02:23:43Z</updated>

		<summary type="html">&lt;p&gt;以“埃拉托色尼选筛法(the Sieve of Eratosthenes)简称埃氏筛法，是古希腊数学家埃拉托色尼(Eratosthenes 274B.C.～194B.C.)提出的一种筛选法...”为内容创建页面&lt;/p&gt;
&lt;p&gt;&lt;b&gt;新页面&lt;/b&gt;&lt;/p&gt;&lt;div&gt;埃拉托色尼选筛法(the Sieve of Eratosthenes)简称埃氏筛法，是古希腊数学家埃拉托色尼(Eratosthenes 274B.C.～194B.C.)提出的一种筛选法。 是针对自然数列中的自然数而实施的，用于求一定范围内的质数，它的容斥原理之完备性条件是p=H~。&lt;br /&gt;
&lt;br /&gt;
=算法描述=&lt;br /&gt;
*先把1删除（现今数学界1既不是质数也不是合数）&lt;br /&gt;
*读取队列中当前最小的数2，然后把2的倍数删去&lt;br /&gt;
*读取队列中当前最小的数3，然后把3的倍数删去&lt;br /&gt;
*读取队列中当前最小的数5，然后把5的倍数删去&lt;br /&gt;
*如上所述直到需求的范围内所有的数均删除或读取&lt;br /&gt;
注：此处的队列并非数据结构队列，如需保留运算结果，处于存储空间的充分利用以及大量删除操作的实施，建议采用链表的数据结构。&lt;br /&gt;
=示例代码=&lt;br /&gt;
&amp;lt;source lang=&amp;quot;c&amp;quot;&amp;gt;&lt;br /&gt;
char * primeNumbersBySieveOfEratosthenes (size_t n) {&lt;br /&gt;
&lt;br /&gt;
  // 初始化素数数组&lt;br /&gt;
  char* num = (char*) malloc(sizeof(char) * n );&lt;br /&gt;
  for ( size_t i = 2; i &amp;lt; n; ++i ) {       &lt;br /&gt;
      num[i] = TRUE;                       &lt;br /&gt;
  }&lt;br /&gt;
  // 按照埃拉托斯特尼筛法，将为基数的倍数的所有数标记为非素数。&lt;br /&gt;
  size_t i = 2;&lt;br /&gt;
  while ( i * i  &amp;lt;= n ) {&lt;br /&gt;
       for (size_t c = 2, idx = 2*i; idx &amp;lt; n; ++c, idx = i * c) {&lt;br /&gt;
           num[idx] = FALSE;&lt;br /&gt;
       }&lt;br /&gt;
       do {&lt;br /&gt;
          ++i;&lt;br /&gt;
       } while ( i * i &amp;lt;= n &amp;amp;&amp;amp; num[i] == FALSE);&lt;br /&gt;
  }&lt;br /&gt;
  return num;&lt;br /&gt;
}&lt;br /&gt;
&amp;lt;/source&amp;gt;&lt;br /&gt;
[[Category:Algorithm]]&lt;/div&gt;</summary>
		<author><name>imported&gt;Soleverlee</name></author>
	</entry>
</feed>