js系列之每天一练成长录三

148 阅读1分钟

写一个函数solution,求比一个数字n小的所有3和5的整数倍数和。 比如10,比它小的3、5整数倍数有: 3,5,6,9, 所以和为23。 比如16, 比它小的3,5整数倍数有: 3,5,6,9,10,12,15,所以和为60(15只计算1次)


function solution(num){
   let ary=[], n=1,n2=1;
   while(3*n<num){
       ary.push(n*3);
       n++;
   }
   while(5*n2<num){
    ary.push(n2*5);
    n2++;
   }
  return Array.from(new Set(ary)).sort(function(a,b){
        return a-b;
   }).reduce((pre,next)=>{
       return pre+next;
   })

}

主要就是先排序,然后再去重,然后再求和,其中es6 有两个语法:

   let ary=[1,2,34,2,1]
   let d=new Set(ary);
   console.log(d);
   { 1, 2, 34 } //Set 可以把数组去重,但是返回的结果会是一个类数组,
   Array.from(d)//可以把类数组转换为数组