它通过从第一个素数2开始,将每个素数的倍数迭代标记为合数。也就是2的下一个合数是4,之后依次是6、8、10、12 ... 100。...当计算到100以后,再找另外一个素数3,从3开始找下一个合数6、9...直至结束后继续循环。当所有的合数都被染色后,剩余的数字就是指定范围内的所有素数了。...举个例子,找到小于30以内的素数:2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29...三、Eratosthenes 算法测试
单元测试:计算1-100内的素数
@Test
public void test_SieveOfEratosthenes() {
SieveOfEratosthenes...:[2,3,5,7,11,13,17,19,23,29,31,37,41,43,47,53,59,61,67,71,73,79,83,89,97]
在 HashMap 中保留了每一个素数在100内对应的合数