• <fieldset id="8imwq"><menu id="8imwq"></menu></fieldset>
  • <bdo id="8imwq"><input id="8imwq"></input></bdo>
    最新文章專題視頻專題問答1問答10問答100問答1000問答2000關鍵字專題1關鍵字專題50關鍵字專題500關鍵字專題1500TAG最新視頻文章推薦1 推薦3 推薦5 推薦7 推薦9 推薦11 推薦13 推薦15 推薦17 推薦19 推薦21 推薦23 推薦25 推薦27 推薦29 推薦31 推薦33 推薦35 推薦37視頻文章20視頻文章30視頻文章40視頻文章50視頻文章60 視頻文章70視頻文章80視頻文章90視頻文章100視頻文章120視頻文章140 視頻2關鍵字專題關鍵字專題tag2tag3文章專題文章專題2文章索引1文章索引2文章索引3文章索引4文章索引5123456789101112131415文章專題3
    問答文章1 問答文章501 問答文章1001 問答文章1501 問答文章2001 問答文章2501 問答文章3001 問答文章3501 問答文章4001 問答文章4501 問答文章5001 問答文章5501 問答文章6001 問答文章6501 問答文章7001 問答文章7501 問答文章8001 問答文章8501 問答文章9001 問答文章9501
    當前位置: 首頁 - 科技 - 知識百科 - 正文

    在javascript中如何實現Emrips反質數枚舉

    來源:懂視網 責編:小OO 時間:2020-11-27 19:35:43
    文檔

    在javascript中如何實現Emrips反質數枚舉

    今天看到一個kata,提出一個“emirps”的概念:一個質數倒轉后得到的是一個不同的質數,這個數叫做“emirps”。例如:13,17是質數,31,71也是質數,13和17是“emirps”。但是質數757,787,797是回文質數,這意味著反轉的數字與原始數字相同,所以它們不被認為是“emirps”。題目要求寫一個函數輸入一個正整數n,返回小于n的“emirps”的個數,其中最大“emirps”、以及所有小于n的“emirps”的和。解題思路為先枚舉出所有小于n的質數,然后剔除回文質數以及顛倒后為合數的數。先寫判斷質數的函數;主要根據三個數學結論。所有合數都是若干個質數的乘積。如一個數可以進行因式分解,那么兩個因數一定是一個小于等于sqrt(n),一個大于等于sqrt(n)。
    推薦度:
    導讀今天看到一個kata,提出一個“emirps”的概念:一個質數倒轉后得到的是一個不同的質數,這個數叫做“emirps”。例如:13,17是質數,31,71也是質數,13和17是“emirps”。但是質數757,787,797是回文質數,這意味著反轉的數字與原始數字相同,所以它們不被認為是“emirps”。題目要求寫一個函數輸入一個正整數n,返回小于n的“emirps”的個數,其中最大“emirps”、以及所有小于n的“emirps”的和。解題思路為先枚舉出所有小于n的質數,然后剔除回文質數以及顛倒后為合數的數。先寫判斷質數的函數;主要根據三個數學結論。所有合數都是若干個質數的乘積。如一個數可以進行因式分解,那么兩個因數一定是一個小于等于sqrt(n),一個大于等于sqrt(n)。
    下面小編就為大家分享一篇javascript實現Emrips反質數枚舉的示例代碼,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧

    今天看到一個kata,提出一個“emirps”的概念:一個質數倒轉后得到的是一個不同的質數,這個數叫做“emirps”。

    例如:13,17是質數,31,71也是質數,13和17是“emirps”。 但是質數757,787,797是回文質數,這意味著反轉的數字與原始數字相同,所以它們不被認為是“emirps”。

    題目要求寫一個函數輸入一個正整數n,返回小于n的“emirps”的個數,其中最大“emirps”、以及所有小于n的“emirps”的和。

    解題思路為先枚舉出所有小于n的質數,然后剔除回文質數以及顛倒后為合數的數。

    先寫判斷質數的函數

    主要根據三個數學結論:

    所有合數都是若干個質數的乘積

    如一個數可以進行因式分解,那么兩個因數一定是一個小于等于sqrt(n),一個大于等于sqrt(n)。

    所有大于3的質數都是6X+1或者6X-1這種形式,也就是6的倍數的相鄰的數,但并不是所有6X+1或者6X-1都是質數。

    第一個結論用反證法即可證明

    第三個結論證明:

    我們把數字都表示為以下形式 6X-1、6X、6X+1、6X+2、6X+3、6X+4 (X為正整數) 6X => 2*3x 6X+2 => 2(3x+1) 6X+3 => 3(2x+1) 6X+4 => 2(3x+2) 可證明這些肯定不為質數,即質數只能為6X-1或者6X-1

    代碼:

    function isPrimeNumber(num){
     
     if(num == 2 || num == 3){
     return true;
     }/*2、3特殊處理*/
     
     if(num % 6 != 1 && num % 6 != 5){
     return false;
     }/*根據結論三排除*/
     
     for(var i=5;i<=Math.sqrt(num);i+=6){
     if(num % i == 0 || num % (i+2) == 0){
     return false;
     }
     }/*根據結論二、結論三排除*/
     
     return true;
    }

    再剔除回文質數以及顛倒后為合數的數

    代碼:

    function emirpNumber(num){
     
     var reverseNumber = Number(String(num).split('').reverse().join(''))
     
     if(reverseNumber != num && isPrimeNumber(reverseNumber)){
     return true;
     }
     else{
     return false;
     }
    }

    最后輸出想要的結果

    代碼:

    function findEmirp(n){
     
     var emirpGroup = [];
     
     for(var i=1;i<n;i++){
     if(isPrimeNumber(i) && emirpNumber(i)){
     emirpGroup.push(i); 
     }
     }
     
     return [
     'n為:' + n,
     '數量為:' + emirpGroup.length,
     '最大數:' + emirpGroup[emirpGroup.length - 1],
     '求和:' + emirpGroup.reduce(function(total,current){
     return total + current;
     })
     ]
    }

    看一下輸出結果和用時

    n=1000000:

    n=10000000:

    上面是我整理給大家的,希望今后會對大家有幫助。

    相關文章:

    使用Javascript如何實現自定義事件機制

    詳細解讀javascript中map數據結構

    使用Javascript如何開發二維周視圖日歷

    有關JS抽象工廠模式(詳細教程)

    在Django與Vue語法中存在沖突問題如何解決

    聲明:本網頁內容旨在傳播知識,若有侵權等問題請及時與本網聯系,我們將在第一時間刪除處理。TEL:177 7030 7066 E-MAIL:11247931@qq.com

    文檔

    在javascript中如何實現Emrips反質數枚舉

    今天看到一個kata,提出一個“emirps”的概念:一個質數倒轉后得到的是一個不同的質數,這個數叫做“emirps”。例如:13,17是質數,31,71也是質數,13和17是“emirps”。但是質數757,787,797是回文質數,這意味著反轉的數字與原始數字相同,所以它們不被認為是“emirps”。題目要求寫一個函數輸入一個正整數n,返回小于n的“emirps”的個數,其中最大“emirps”、以及所有小于n的“emirps”的和。解題思路為先枚舉出所有小于n的質數,然后剔除回文質數以及顛倒后為合數的數。先寫判斷質數的函數;主要根據三個數學結論。所有合數都是若干個質數的乘積。如一個數可以進行因式分解,那么兩個因數一定是一個小于等于sqrt(n),一個大于等于sqrt(n)。
    推薦度:
    標簽: js javascript 質數
    • 熱門焦點

    最新推薦

    猜你喜歡

    熱門推薦

    專題
    Top
    主站蜘蛛池模板: 青青青青久久精品国产h| 久久青草国产精品一区| 亚洲日韩国产AV无码无码精品| 精品无码国产自产拍在线观看| 亚洲国产精品VA在线观看麻豆 | 国产精品91视频| 久久久精品2019免费观看| 国产激情精品一区二区三区| 欧美精品福利视频| 少妇人妻偷人精品免费视频| 凹凸国产熟女精品视频app| 国产伦精品一区二区三区| 久久99精品国产麻豆婷婷| 久久精品无码一区二区日韩AV| 久久久久久久久久久免费精品| 精品免费tv久久久久久久| 国产玖玖玖九九精品视频| 欧美日韩成人精品久久久免费看| 国产欧美精品一区二区色综合| 成人精品视频99在线观看免费| 天天视频国产精品| 亚洲AV无码成人网站久久精品大 | 亚洲精品无码AV人在线播放 | 久久这里只精品国产99热| 久久99精品久久久久久久久久| 亚欧无码精品无码有性视频| 精品久久综合1区2区3区激情| 国产成人综合久久精品尤物| 久久精品成人免费国产片小草| 久久国产亚洲精品麻豆| 国产精品无套内射迪丽热巴| 无码aⅴ精品一区二区三区浪潮| 亚洲一区二区精品视频 | 久久五月精品中文字幕| 国产精品va在线观看无码| 56prom精品视频在放免费| 亚洲av无码成人精品区在线播放 | 亚洲精品无码AV中文字幕电影网站| 国产高清一级毛片精品| 午夜精品视频在线| 亚洲精品国产V片在线观看 |