(js)leetcode 1748. 唯一元素的和

题目:

给你一个整数数组 nums 。数组中唯一元素是那些只出现 恰好一次 的元素。

请你返回 nums 中唯一元素的 和 。

示例 1:

输入:nums = [1,2,3,2]
输出:4
解释:唯一元素为 [1,3] ,和为 4 。
示例 2:

输入:nums = [1,1,1,1,1]
输出:0
解释:没有唯一元素,和为 0 。
示例 3 :

输入:nums = [1,2,3,4,5]
输出:15
解释:唯一元素为 [1,2,3,4,5] ,和为 15 。

提示:

1 <= nums.length <= 100
1 <= nums[i] <= 100

思路:

1. 第一次遍历数组,先计算每个元素出现的次数

2. 第二次遍历map,求和

代码实现:

/**
 * @param {number[]} nums
 * @return {number}
 */
var sumOfUnique = function (nums) {
    let map = new Map(), sum = 0;
    nums.forEach(item => {
        let count = map.get(item) || 0;
        map.set(item, ++count)
    });

    for(let [key, value] of map) {
        if(value === 1) {
            sum += key;
        }
    }
    return sum;
};

运行结果:

猜你喜欢

转载自blog.csdn.net/M_Eve/article/details/113949767
今日推荐