当前位置:主页   - 电脑 - 程序设计 - JAVA
Java 小例子:求素数
来源:网络   作者:   更新时间:2012-06-13
收藏此页】    【字号    】    【打印】    【关闭

  素数(质数)指的是不能被分解的数,除了 1 和它本身之外就没有其它数能够整除。这里是一个小例子,说明如何求取十万以内的所有素数。

  素数的分布没有规律可言,所以要检验一个数是不是素数,就必须将它同所有小于它的数作除法。不过有一个简便的方法,就是不需要检验所有小于它的数,而只要检验所有小于它的素数。如果所有小于它的素数都不能将其整除,那么它就是素数。

public class Primes {  
   
    public static void main(String[] args) {  
        // 求素数  
        List<Integer> primes = getPrimes(100000);  
   
        // 输出结果  
        for (int i = 0; i < primes.size(); i++) {  
            Integer prime = primes.get(i);  
            System.out.printf("%8d", prime);  
            if (i % 10 == 9) {  
                System.out.println();  
            }  
        }  
    }  
   
    /** 
     * 求 n 以内的所有素数 
     * 
     * @param n 范围 
     * 
     * @return n 以内的所有素数 
     */ 
    private static List<Integer> getPrimes(int n) {  
        List<Integer> result = new ArrayList<Integer>();  
        result.add(2);  
 
        for (int i = 3; i <= n; i += 2) {  
            if (!divisible(i, result)) {  
                result.add(i);  
            }  
        }  
   
        return result;  
    }  
   
    /** 
     * 判断 n 是否能被整除 
     * 
     * @param n      要判断的数字 
     * @param primes 包含素数的列表 
     * 
     * @return 如果 n 能被 primes 中任何一个整除,则返回 true。 
     */ 
    private static boolean divisible(int n, List<Integer> primes) {  
        for (Integer prime : primes) {  
            if (n % prime == 0) {  
                return true;  
            }  
        }  
        return false;  
    }  
} 

其它资源
来源声明

版权与免责声明
1、本站所发布的文章仅供技术交流参考,本站不主张将其做为决策的依据,浏览者可自愿选择采信与否,本站不对因采信这些信息所产生的任何问题负责。
2、本站部分文章来源于网络,其版权为原权利人所有。由于来源之故,有的文章未能获得作者姓名,署“未知”或“佚名”。对于这些文章,有知悉作者姓名的请告知本站,以便及时署名。如果作者要求删除,我们将予以删除。除此之外本站不再承担其它责任。
3、本站部分文章来源于本站原创,本站拥有所有权利。
4、如对本站发布的信息有异议,请联系我们,经本站确认后,将在三个工作日内做出修改或删除处理。
请参阅权责声明