code war 天天一练(4)

工作闲暇做一道题:

code war 天天一练(4)

这个题的意思是:删除一样的相邻元素,返回新数组。

这里用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,保留了当前元素。

这道题比较简单。

再来一个简单的题:

code war 天天一练(4)

这个很简单,我就直接贴出答案了:

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)
}