<rt id="bn8ez"></rt>
<label id="bn8ez"></label>

  • <span id="bn8ez"></span>

    <label id="bn8ez"><meter id="bn8ez"></meter></label>

    posts - 73,  comments - 55,  trackbacks - 0
    1。自然數是0,1,2……
    2。素數是2,3,5……(不包括1的只能背1和它本身整除的自然數)

    public class Test
    {
    ?/*
    ? * 最普通的算法:
    ? * 打印num以內的素數并返回素數個數
    ? * n、m分別為外、內層循環,i是第幾個素數,s是素數個數
    ? */
    ?public int prime(int num){
    ??int n,m,i=0,s=0;
    ??label1:
    ??for(n=2;n<=num;n++)
    ??{
    ???for(m=2;m<=n/2;m++)
    ???{
    ????if(n%m==0)
    ????continue label1;
    ???}
    ???s++;
    ???i++;
    ???System.out.println("第"+i+"個素數是:"+n);
    ??}
    ??return s;
    ?}
    ?
    ?public static void main(String args[]){
    ??Test test = new Test();
    ??int sum = test.prime(1000);
    ??System.out.println("共"+sum+"個素數");
    ?}
    }

    【1】求10000以內的所有素數。
    素數是除了1和它本身之外再不能被其他數整除的自然數。由于找不到一個通項公式來表示所有的素數,所以對于數學家來說,素數一直是一個未解之謎。像著名的 哥德巴赫猜想、孿生素數猜想,幾百年來不知吸引了世界上多少優秀的數學家。盡管他們苦心鉆研,嘔心瀝血,但至今仍然未見分曉。
    自從有了計算機之后,人們借助于計算機的威力,已經找到了2216091以內的所有素數。
    求素數的方法有很多種,最簡單的方法是根據素數的定義來求。對于一個自然數N,用大于1小于N的各個自然數都去除一下N,如果都除不盡,則N為素數,否則N為合數。
    但是,如果用素數定義的方法來編制計算機程序,它的效率一定是非常低的,其中有許多地方都值得改進。
    第一,對于一個自然數N,只要能被一個非1非自身的數整除,它就肯定不是素數,所以不
    必再用其他的數去除。
    第二,對于N來說,只需用小于N的素數去除就可以了。例如,如果N能被15整除,實際
    上就能被3和5整除,如果N不能被3和5整除,那么N也決不會被15整除。
    第三,對于N來說,不必用從2到N一1的所有素數去除,只需用小于等于√N(根號N)的所有素數去除就可以了。這一點可以用反證法來證明:
    如果N是合數,則一定存在大于1小于N的整數d1和d2,使得N=d1×d2。
    如果d1和d2均大于√N,則有:N=d1×d2>√N×√N=N。
    而這是不可能的,所以,d1和d2中必有一個小于或等于√N。
    基于上述分析,設計算法如下:
    (1)用2,3,5,7逐個試除N的方法求出100以內的所有素數。
    (2)用100以內的所有素數逐個試除的方法求出10000以內的素數。
    首先,將2,3,5,7分別存放在a[1]、a[2]、a[3]、a[4]中,以后每求出一個素數,只要不大于100,就依次存放在A數組中的一個單元 中。當我們求100—10000之間的素數時,可依次用a[1]-a[2]的素數去試除N,這個范圍內的素數可以不保存,直接打印。

    【2】用篩法求素數。
    簡單介紹一下厄拉多塞篩法。厄拉多塞是一位古希臘數學家,他在尋找素數時,采用了一種與眾不同的方法:先將2-N的各數寫在紙上:

    在2的上面畫一個圓圈,然后劃去2的其他倍數;第一個既未畫圈又沒有被劃去的數是3,將它畫圈,再劃去3的其他倍數;現在既未畫圈又沒有被劃去的第一個數 是5,將它畫圈,并劃去5的其他倍數……依次類推,一直到所有小于或等于N的各數都畫了圈或劃去為止。這時,表中畫了圈的以及未劃去的那些數正好就是小于 N的素數。

    這很像一面篩子,把滿足條件的數留下來,把不滿足條件的數篩掉。由于這種方法是厄拉多塞首先發明的,所以,后人就把這種方法稱作厄拉多塞篩法。
    在計算機中,篩法可以用給數組單元置零的方法來實現。具體來說就是:首先開一個數組:a[i],i=1,2,3,…,同時,令所有的數組元素都等于下標 值,即a[i]=i,當i不是素數時,令a[i]=0 。當輸出結果時,只要判斷a[i]是否等于零即可,如果a[i]=0,則令i=i+1,檢查下一個a[i]。
    篩法是計算機程序設計中常用的算法之一。

    【3】用6N±1法求素數。
    任何一個自然數,總可以表示成為如下的形式之一:
    6N,6N+1,6N+2,6N+3,6N+4,6N+5 (N=0,1,2,…)
    顯然,當N≥1時,6N,6N+2,6N+3,6N+4都不是素數,只有形如6N+1和6N+5的自然數有可能是素數。所以,除了2和3之外,所有的素數都可以表示成6N±1的形式(N為自然數)。
    根據上述分析,我們可以構造另一面篩子,只對形如6 N±1的自然數進行篩選,這樣就可以大大減少篩選的次數,從而進一步提高程序的運行效率和速度。

    在程序上,我們可以用一個二重循環實現這一點,外循環i按3的倍數遞增,內循環j為0-1的循環,則2(i+j)-1恰好就是形如6N±1的自然數。
    posted on 2006-06-16 15:17 保爾任 閱讀(4712) 評論(1)  編輯  收藏

    FeedBack:
    # re: 如何求素數
    2010-09-04 03:10 | leonmax
    “i是第幾個素數,s是素數個數”
    不懂……i和s完全是同步++的,不是重復了嗎?有區別嗎?  回復  更多評論
      

    只有注冊用戶登錄后才能發表評論。


    網站導航:
     

    <2025年5月>
    27282930123
    45678910
    11121314151617
    18192021222324
    25262728293031
    1234567

    常用鏈接

    留言簿(4)

    隨筆分類

    隨筆檔案

    文章分類

    文章檔案

    搜索

    •  

    最新評論

    閱讀排行榜

    評論排行榜

    主站蜘蛛池模板: 亚洲AV无码国产丝袜在线观看| 亚洲一区免费在线观看| 久久成人免费大片| 亚洲国产AV无码一区二区三区| 综合久久久久久中文字幕亚洲国产国产综合一区首 | 亚洲av日韩片在线观看 | 波多野结衣一区二区免费视频 | 国产一区二区三区免费看| a级片免费在线播放| 中文无码亚洲精品字幕| 亚洲综合在线另类色区奇米| 久久精品a一国产成人免费网站| 久久久久久久国产免费看| 亚洲va在线va天堂成人| 亚洲精品乱码久久久久久中文字幕| 啦啦啦高清视频在线观看免费 | 亚洲av无码一区二区三区不卡| 最近2019中文字幕免费看最新| 久久久久久久久久久免费精品| 国产成人精品日本亚洲直接| 国产亚洲人成网站在线观看不卡| 免费网站看v片在线香蕉| 美丽姑娘免费观看在线观看中文版| 国产精品久久久久久亚洲小说| 亚洲国语在线视频手机在线| 国产亚洲av人片在线观看| 成年午夜视频免费观看视频| 午夜免费啪视频在线观看| 一级特黄特色的免费大片视频 | 国产卡一卡二卡三免费入口| 一个人免费视频观看在线www | 免费高清资源黄网站在线观看| 日韩电影免费在线观看中文字幕| 看一级毛片免费观看视频| 亚洲an日韩专区在线| 亚洲av日韩av无码| 亚洲色欲一区二区三区在线观看| 免费在线看片网站| 思思99re66在线精品免费观看| 1000部拍拍拍18勿入免费凤凰福利| 黄网站色视频免费在线观看的a站最新|