工作閑暇做一道題: 這個題的意思是:刪除一樣的相鄰元素,返回新數組。 這裡用Array.filter方法最好了,我的答案如下: 這裡註意,filter是不會修改原數組的,它只返回新數組,並且還有一個功能:刪除返回false的值,保留返回true的值。 還有第二個答案: 這個是用另一個空數組來轉載符合 ...
工作閑暇做一道題:
這個題的意思是:刪除一樣的相鄰元素,返回新數組。
這裡用Array.filter方法最好了,我的答案如下:
var uniqueInOrder=function(iterable){ var arr = typeof(iterable) === 'string' ? iterable.split('') : iterable; var pre = ''; return arr.filter(function(i){ if(i === pre){ return false; }else{ pre = i; return true; } }) }
這裡註意,filter是不會修改原數組的,它只返回新數組,並且還有一個功能:刪除返回false的值,保留返回true的值。
還有第二個答案:
var uniqueInOrder=function(iterable){ var arr = typeof(iterable) === 'string' ? iterable.split('') : iterable; var pre = '',result = []; arr.map(function(i){ if(i !== pre){ result.push(pre = i); } }); return result; }
這個是用另一個空數組來轉載符合條件的值。
提交後在Solutions區域看到了一個很聰明的答案:
var uniqueInOrder = function (iterable){ return [].filter.call(iterable, (function (a, i) { return iterable[i - 1] !== a })); }
這裡用call方法使得iterable巧妙的調用了array.filter,這對不知是數組還是字元串的iterable來說,同樣適用,不用再在前面費盡心思將字元串轉變成數組進行操作。
然後他利用了filter返回值的特點,將每個元素依次和前面的元素進行對比,若不相等則返回true,保留了當前元素。
這道題比較簡單。
再來一個簡單的題:
這個很簡單,我就直接貼出答案了:
function average(scores) { var result = 0; scores.map(i=>result+=i); return Math.round(result/scores.length); }
按例展出結論區最好的方法:
function average(scores) { return Math.round(scores.reduce((x, y) => x+y, 0) / scores.length) }