codecamp

质素求和算法挑战

方法一:

function sumPrimes(num) {
  var res=getarr(num).reduce(function(a,b){  
    return a+b;
  });
  return res;
}


function getarr(num){   //返回质数数组
  var arr=[];
  outer:for(var i=2;i<=num;i++){
    for(var j=2;j<i;j++){
      if( i%j===0 ){
        continue outer;
      }
    }

    
    arr.push(i);
  }
  return arr;
}


sumPrimes(10);

方法二:

function sumPrimes(num) {
  var r=0;
  for(var i=2;i<=num;i++){
    var isPrime = true;
    for(var j=2;j<=i;j++){
      if(i%j===0 && i!==j){
        isPrime = false;
        break;
      }
    }
    if(isPrime){
      r+=i;
    }
  }
  return r;
}


sumPrimes(10);
斐波纳契奇数求和算法挑战
最小公倍数算法挑战
温馨提示
下载编程狮App,免费阅读超1000+编程语言教程
取消
确定
目录

HTML5&CSS

JavaScript

关闭

MIP.setData({ 'pageTheme' : getCookie('pageTheme') || {'day':true, 'night':false}, 'pageFontSize' : getCookie('pageFontSize') || 20 }); MIP.watch('pageTheme', function(newValue){ setCookie('pageTheme', JSON.stringify(newValue)) }); MIP.watch('pageFontSize', function(newValue){ setCookie('pageFontSize', newValue) }); function setCookie(name, value){ var days = 1; var exp = new Date(); exp.setTime(exp.getTime() + days*24*60*60*1000); document.cookie = name + '=' + value + ';expires=' + exp.toUTCString(); } function getCookie(name){ var reg = new RegExp('(^| )' + name + '=([^;]*)(;|$)'); return document.cookie.match(reg) ? JSON.parse(document.cookie.match(reg)[2]) : null; }