zoukankan      html  css  js  c++  java
  • Slasher Flick(算法)

    题目

    打不死的小强!

    返回一个数组被截断n个元素后还剩余的元素,截断从索引0开始。

    提示

    Array.slice()

    Array.splice()

    思路

    既然题目已经给了提示可以用到的函数,那么我们就可以分别用这两种函数得出两种解题思路。

    解法一

    slice() 方法会基于当前数组中的一个或多个项创建一个新数组。可以接受一或两个参数,即返回项的起始和结束位置。  [起始,结束)

    slice() 不会影响原数组。 

    用以下代码,问题可简单解决:

    arr.slice(howMany)

    因为数组项的索引从0开始,所以起始位置可设为截断项  howMany ,不指定第二个参数,则结束位置一直到整个数组末尾。 

    解法二

    splice() 是个很灵活也很强大的方法,用它可以在数组中进行数组项的删除、插入、替换。它可以接收三个参数:  起始位置 、  要删除的项数 、  要插入的任意数量的项 。 

    splice() 方法始终会返回一个数组,该数组包含从原数组中删除的项(若没删除任何值,则返回空数组)。这个方法会修改原数组。 

    如果想在  return 时直接返回题目要求的  一个数组被截断n个元素后还剩余的元素 ,则可以用  splice() 删除最后要得到的值。当然啦,从逻辑上来说,这样写与题意是偏离的(题中要求保留剩余的元素,而我们修改数组并删除了这部分),但从返回结果上来看是正确的。 

    解法

    解法一

    function slasher(arr, howMany) {
      // it doesn't always pay to be first
      return arr.slice(howMany);
    }

    解法二

    function slasher(arr, howMany) {
      // it doesn't always pay to be first  
      return arr.splice(howMany,arr.length);
    }

    测试

    slasher([1, 2, 3], 2) 应该返回  [3] . 

    slasher([1, 2, 3], 0) 应该返回  [1, 2, 3] . 

    slasher([1, 2, 3], 9) 应该返回  [] . 

    slasher([1, 2, 3], 4) 应该返回  [] . 

    slasher(["burgers", "fries", "shake"], 1) 应该返回  ["fries", "shake"] .

  • 相关阅读:
    第三次冲刺
    [操作系统]实验四
    第二个冲刺5.0
    第二个冲刺
    学术诚信与职业道德--个人感想
    软件工程——sprint 1回顾总结
    [读书笔记]
    sprint5.0
    [操作系统]3.0
    学习进度条
  • 原文地址:https://www.cnblogs.com/codepen2010/p/6824915.html
Copyright © 2011-2022 走看看