Javascript数组编程练习

本文提供了一系列实用的数组操作函数,包括查找元素位置、计算元素总和、移除特定元素、添加和删除元素、合并数组、插入元素、统计元素出现次数、查找重复元素、计算元素平方、查找元素所有位置等。这些函数覆盖了数组处理的基本需求,适用于JavaScript编程。

1, 找出元素 item 在给定数组 arr 中的位置

输出描述: 如果数组中存在 item,则返回元素在数组中的位置,否则返回 -1

输入例子: indexOf([ 1, 2, 3, 4 ], 3)

输出例子: 2

function indexOf(arr, item) {  
    for (var i=0; i<arr.length; i++) {    
        if(arr[i] === item) {      
            return i;
        
    
    return -1;
}
indexOf([1,2,3,4], 3);

2,题目描述计算给定数组 arr 中所有元素的总和

输入描述: 数组中的元素均为 Number 类型

输入例子: sum([ 1, 2, 3, 4 ])

输出例子: 10

function sum(arr) {    
    var s = 0;    
    for (var in arr) {
        s += arr[x];
    }    
    return s;
}
sum([ 1, 2, 3, 4 ]);

3,移除数组 arr 中所有值与 item 相等的元素。不要直接修改数组 arr,结果返回新的数组

输入例子: remove([1, 2, 3, 4, 2], 2)

输出例子: [1, 3, 4]

function remove(arr, item) {
    var _arr = [];    
    for (var in arr) {        
        if (arr[x] !== item) {
            _arr.push(arr[x]);
        }
    }
    return _arr;
}
remove([1, 2, 3, 4, 2], 2);

4, 移除数组 arr 中所有值与 item 相等的元素,直接在给定的 arr 数组上进行操作,并将结果返回

输入例子: removeWithoutCopy([1, 2, 2, 3, 4, 2, 2], 2)

输出例子: [1, 3, 4]

function removeWithoutCopy(arr, item) {
    var len = arr.length;    
    for (var i = len-1; i >= 0; i--) {        
        if (arr[i] === item) {
            arr.splice(i, 1);
        }
    }    
    return arr;
}
removeWithoutCopy([1, 2, 2, 3, 4, 2, 2], 2)

5,在数组 arr 末尾添加元素 item。不要直接修改数组 arr,结果返回新的数组

输入例子: append([1, 2, 3, 4], 10)

输出例子: [1, 2, 3, 4, 10]

function append(arr, item) {
    var _arr = slice(0);    
    return _arr.push(item);
}
append([1, 2, 3, 4],  10)

6,删除数组 arr 最后一个元素。不要直接修改数组 arr,结果返回新的数组

输入例子: truncate([1, 2, 3, 4])

输出例子: [1, 2, 3]

function truncate(arr) {    
    return arr.slice(0,-1)
}
truncate([1, 2, 3, 4])

7,在数组 arr 开头添加元素 item。不要直接修改数组 arr,结果返回新的数组

输入例子: prepend([1, 2, 3, 4], 10)

输出例子: [10, 1, 2, 3, 4]

function prepend(arr, item) {
    var _arr = [item]    
    return _arr.concat(arr);
}
prepend([1, 2, 3, 4], 10)

8,删除数组 arr 第一个元素。不要直接修改数组 arr,结果返回新的数组

输入例子: curtail([1, 2, 3, 4])

输出例子: [2, 3, 4]

function curtail(arr) {
    var _arr = arr.slice(0)    
    return _arr.slice(1)
}
curtail([1, 2, 3, 4])

9,合并数组 arr1 和数组 arr2。不要直接修改数组 arr,结果返回新的数组

输入例子: concat([1, 2, 3, 4], ['a', 'b', 'c', 1])

输出例子: [1, 2, 3, 4, 'a', 'b', 'c', 1]

function concat(arr1, arr2) {
    var _arr = arr1.concat(arr2)    
    return _arr
}
concat([1, 2, 3, 4], ['a''b''c', 1])

10, 在数组 arr 的 index 处添加元素 item。不要直接修改数组 arr,结果返回新的数组

输入例子: insert([1, 2, 3, 4], 'z', 2)

输出例子: [1, 2, 'z', 3, 4]

function insert(arr, item, index) {
    var _arr = arr.slice(0);    
    //0 为要删除的个数, item为向数组添加新的项
    _arr.splice(index, 0 ,item);    
    return _arr;
}
insert([1, 2, 3, 4], 'z', 2)

11,统计数组 arr 中值等于 item 的元素出现的次数

输入例子: count([1, 2, 4, 4, 3, 4, 3], 4)

输出例子: 3

function count(arr, item) {
    var c = 0;    
    for (var in arr) {        
        if (arr[x] == item) {
            c += 1;
        }
    }   
    return c;
}
count([1, 2, 4, 4, 3, 4, 3], 4)

12,找出数组 arr 中重复出现过的元素

输入例子: duplicates([1, 2, 4, 4, 3, 3, 1, 5, 3]).sort()

输出例子: [1, 3, 4]

function duplicates(arr) {
    var a = [];    
    for(var i=0; i<arr.length; i++) {        
        for(var j=i+1;j<arr.length;j++){
            arr[i]==arr[j]&&a.indexOf(arr[i])==-1&&a.push(arr[i]);
        }
    }    
    return a;
}
duplicates([1, 2, 4, 4, 3, 3, 1, 5, 3]).sort((i,j) => {return i-j;} )

13,为数组 arr 中的每个元素求二次方。不要直接修改数组 arr,结果返回新的数组

输入例子: square([1, 2, 3, 4])

输出例子: [1, 4, 9, 16]

function square(arr) {
    var _arr = arr.slice(0);
    return _arr.map(item => item * item)
}
square([1, 2, 3, 4])

14, 在数组 arr 中,查找值与 item 相等的元素出现的所有位置

输入例子: findAllOccurrences('abcdefabc', 'a').sort()

输出例子: [0, 6]

function findAllOccurrences(str, target) {    
    var arr = str.split('');    
    var _arr = [];
    arr.map((item, index) => {
        item === target && _arr.push(index)
    })    
    return _arr;
}
findAllOccurrences('abcdefabc''a').sort((i,j) => {return i-j;})

评论
成就一亿技术人!
拼手气红包6.0元
还能输入1000个字符
 
红包 添加红包
表情包 插入表情
 条评论被折叠 查看
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值