工作闲暇做一道题:
这个题的意思是:删除一样的相邻元素,返回新数组。
这里用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) }