剑指Offer打卡56-II. 数组中数字出现的次数 II

Posted 余光、

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了剑指Offer打卡56-II. 数组中数字出现的次数 II相关的知识,希望对你有一定的参考价值。

剑指 Offer56-II. 数组中数字出现的次数 II

JavaScript剑指Offer题解

🚀包含数组、对象、链表、堆栈、树等经典题型
☕️每天一道,轻松不累
💬详细的题目解析,收藏方便阅读
🙏在线star地址

在线阅读地址

在线阅读地址

题目描述

在一个数组 nums 中除一个数字只出现一次之外,其他数字都出现了三次。请找出那个只出现一次的数字。

示例 1:

输入:nums = [3,4,3,3]
输出:4

示例 2:

输入:nums = [9,1,7,9,7,9,7]
输出:1

题解一:数学思想

/**
 * @param number[] nums
 * @return number
 */
var singleNumber = function (nums) 
    const compare = [...new Set(nums)].map(v => v * 3).reduce((a, b) => a + b)
    const res = nums.reduce((a, b) => a + b);
    return (compare - res) / 2
;

写在最后

本篇是剑指Offer的第23题,俗话说好的合理的数据结构+算法才是写好代码的关键,不妨跟我一起来吧~

热门开源项目

以上是关于剑指Offer打卡56-II. 数组中数字出现的次数 II的主要内容,如果未能解决你的问题,请参考以下文章

剑指Offer打卡56-II. 数组中数字出现的次数 II

乱序版 ● 剑指offer每日算法题打卡题解——位运算 (题号56)

1787. 使所有区间的异或结果为零 / 剑指Offer56 - I. 数组中数字出现的次数 / 剑指Offer56 - II. 数组中数字出现的次数 II / 剑指Offer57.和为s的两个数字(

剑指 Offer 56 - II. 数组中数字出现的次数 II

算法剑指 Offer 56 - II. 数组中数字出现的次数 II 重刷

剑指 Offer 56 - II. 数组中数字出现的次数 II(二进制求和模运算)