寫一個函式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)//可以把類陣列轉換為陣列
複製程式碼