11.为数组 arr 中的每个元素求二次方.不要直接修改数组 arr,结果返回新的数组 function square(arr) { var resultArr=new Array(); for(var i=0;i<arr.length;i++){ resultArr[i]=arr[i]*arr[i]; } return resultArr; } 12.在数组 arr 中,查找值与 item 相等的元素出现的所有位置 function findAllOccurrences(arr, target…
来自牛客网的js编程题 1.移除数组 arr 中的所有值与 item 相等的元素.不要直接修改数组 arr,结果返回新的数组 function remove(arr, item) { if(!Array.isArray(arr)) return -1; for(var i=0;i<arr.length;i++){ if(arr[i]==item){ arr.splice(i,1); i--; //这里是因为用splice删除一个元素之后,下一个元素替换当前元素的位置 } } return arr…
24.柯里化 首先想解释一下,“柯里化”的意思, [在计算机科学中,柯里化(Currying)是把接受多个参数的函数变换成接受一个单一参数(最初函数的第一个参数)的函数,并且返回接受余下的参数且返回结果的新函数的技术.这个技术由 Christopher Strachey 以逻辑学家 Haskell Curry 命名的,尽管它是 Moses Schnfinkel 和 Gottlob Frege 发明的.]——from 百度百科 题目描述 已知 fn 为一个预定义函数,实现函数 curryIt,调用…
14. 题目描述 实现一个打点计时器,要求 1.从 start 到 end(包含 start 和 end),每隔 100 毫秒 console.log 一个数字,每次数字增幅为 1 2.返回的对象中需要包含一个 cancel 方法,用于停止定时操作 3.第一个数需要立即输出 function count(start,end){ console.log(start); var counter; counter=setInterval(function(){ if(start<end){ conso…
7.合并数组 arr1 和数组 arr2.不要直接修改数组 arr,结果返回新的数组 function concat(arr1, arr2) { return arr1.concat(arr2); } 还是考察concat方法,不会修改原数组. 8.在数组 arr 的 index 处添加元素 item.不要直接修改数组 arr,结果返回新的数组 function insert(arr, item, index) { var arrRight=arr.slice(index,arr.length)…
3.在数组 arr 末尾添加元素 item.不要直接修改数组 arr,结果返回新的数组 主要考察数组的concat方法,代码如下: arr.concat(item); concat 方法不修改原数组. 4.删除数组 arr 最后一个元素.不要直接修改数组 arr,结果返回新的数组 function truncate(arr) { return arr.slice(0,arr.length-1); } slice 方法不修改原数组. 5.在数组 arr 开头添加元素 item.不要直接修改数组 a…
2.移除数组 arr 中的所有值与 item 相等的元素,直接在给定的 arr 数组上进行操作,并将结果返回 function removeWithoutCopy(arr, item) { if(!Array.isArray(arr)) return -1; for(var i=0;i<arr.length;i++){ if(arr[i]==item){ arr.splice(i,1); i--; } } return arr; } 修改原数组,通过率100% 可以与上一个对比来看…
一.JavaScript数组的奇葩 大多数语言会要求数组的元素是同个类型, 但是JavaScript允许数组元素为多种类型. var arr = ["羽毛球", 666, {"json:":"666"}]; console.log(arr.length); 二.JavaScript 数组的两种声明 1.var arr = [元素]; var arr = ["坚持"]; 2.new Array(); 或者 var arr2 =…
欢迎指导与讨论:) 前言 函数式编程能使我们的代码结构变得简洁,让代码更接近于自然语言,易于理解. 一.减少不必要的函数嵌套代码 (1)当存在函数嵌套时,若内层函数的参数与外层函数的参数一致时,可以这样子写. // 一个内层函数 function call( num, index ){ console.log (num + ' ' + index ); } // 啰嗦的写法 [ 1, 2, 3 ].map(function( num, index ){ return call( num, ind…
JavaScript学习笔记之数组(二) 1.['1','2','3'].map(parseInt) 输出什么,为什么? ['1','2','3'].map(parseInt)//[1,NaN,NaN] // map有三个参数:数组元素,元素索引,数组本身 // parseInt有两个参数,元素本身以及进制parseInt(string,radix) ['1','2','3'].map(parseInt); ['1','2','3'].map(function(item,index,array)…