第一题
function fun(){
for(var i=0,arr=[];i<3;i++){
arr[i]=function(){
console.log(i)
}
}
return arr;
}
var funs=fun();
funs[0]();//3
funs[1]();//3
funs[2]();//3
第二题
去掉数组中非数字字符,并给每个数字加+1
var arr=[1,2,3,“a”,4,“b”]
for(var i=arr.length-1;i>=0;i--){
if(typeof arr[i]==="number"){
arr[i]++ ;
}else{
arr.splice(i,1);
}
}
第三题
在两个排好序的数组中,高效率的找出相同的元素,放入新数组
var arr1=[1,3,7,9,12,37,45]
var arr2=[2,4,9,13,45,88,92]
for(var i=0,j=0,arr=[];i<arr1.length&&j<arr2.length;){
if(arr1[i]>arr2[j]){
j++;
}else if(arr1[i]<arr2[j]){
i++;
}else{
arr.push(arr1[i]);
i++;
j++;
}
}
第四题
找出一个排好序的数组中,两个元素相加和为19的元素组合,考虑程序的执行效率
var arr=[1,2,4,6,7,11,12,15,17]
for(var i=0,j=arr.length-1;i<j;){
if(arr[i]+arr[j]<19){
i++;
}else if(arr[i]+arr[j]>19){
j--;
}else{
console.log(`${
arr[i]}+${
arr[j]}`);
i++;
j--;
}
}
第五题
统计一个字符串中每种字符出现的次数?出现次数最多的是哪个字?共出现几次
for(var i=0,arr=[];i<str.length;i++){
var char=str[i];
if(arr[char]===undefined){
arr[char]=1
}else{
arr[char]++;
}
}
/* 这种方法也可以
var res=str.split("").reduce(function(prev,elem){
if(prev[elem]!==undefined){
prev[elem]++
}else{
prev[elem]=1;
}
return prev;
},{})
console.log(res);
*/
var maxChar,count=0;
for(var key in arr){
if(arr[key]>count){
maxChar=key;
count=arr[key];
}
}
第六题
[]-[], []+[] 分别输出多少
- 法计算永远试图将左右两边的值都转为数字,因为只有数字可以做减法。所以,自动调用Number()
Number([]) = 0 记住。
[]-[]等于0, []-1等于-1
+ 法则完全不同。两个对象相加,会自动调用两个对象的toString方法,将两个对象转为字符串,然后执行字符串拼接。
[].toStirng() = “”,因为数组没有值,所以转为空字符串
[]+[],等于""+"",返回""
[1,2,3]+[4,5,6], 等于"1,2,3"+“4,5,6” 结果:
“1,2,34,5,6”
第七题
function fun(o){
o.name="西西";
o={
};
o.name="小丽";
}
var obj={
name:"小红",age:11};
fun(obj);
console.log(obj);
> {
name: "西西", age: 11}
第八题
深克隆
function clone(obj){
var newObj={
};
if(obj==null){
return null;
}else if({
}.toString.call(obj)==="[object Array]"){
var newArr=[];
newArr=obj.slice();
return newArr;
}
for(var key in obj){
if(typeof obj[key]!=="object")//typeof null 也是object
{
newObj[key]=obj