前端JavaScript算法找出只出现一次的数字

 更新时间:2022年07月09日 08:59:37   作者:掘金安东尼  
这篇文章主要为大家介绍了前端JavaScript算法找出只出现一次的数字的算法示例详解,有需要的朋友可以借鉴参考下,希望能够有所帮助,祝大家多多进步,早日升职加薪

题目:只出现一次的数字

给定一个非空整数数组,除了某个元素只出现一次以外,其余每个元素均出现两次。找出那个只出现了一次的元素。

说明:

你的算法应该具有线性时间复杂度。 你可以不使用额外空间来实现吗?

示例 1:

输入: [2,2,1]
输出: 1

示例 2:

输入: [4,1,2,1,2]
输出: 4

解:

第一个反应用 map 来解,时间复杂度 O(n),是线性的,满足题意,只不过空间复杂度消耗是 O(n),怎样降低空间复杂度,在方法二中讲;

解法一:用 map 来解:

/**
 * @param {number[]} nums
 * @return {number}
 */
var singleNumber = function(nums) {
   let map = new Map();
    for(let i = 0; i<nums.length;i++){
        if(map.has(nums[i])){
            map.set(nums[i],map.get(nums[i])+1);
        }else{
            map.set(nums[i],1)
        }
    }
    for(let [key,value] of map.entries()){
        if(value===1){
            return key
        }
    }

};

解法二:用 异或 解

重点当然就是在怎么理解:不使用额外空间来实现

其实就是就要在数组本身上进行操作,异或操作可以帮助我们实现这一点;

异或(eor)是一个数学运算符。它应用于逻辑运算。两个相等的数异或为0;两个值不相同,则异或结果为1;一个不为0的数与0异或为这个数本身;

/**
 * @param {number[]} nums
 * @return {number}
 */
var singleNumber = function(nums) {
  for (var i = 1; i < nums.length; i++) {
    nums[0] = nums[0] ^ nums[i];    // 把所有的元素都异或到nums[0]上。
  }
  return nums[0];
};

以上就是前端JavaScript算法找出只出现一次的数字的详细内容,更多关于JavaScript算法只出现一次数字的资料请关注脚本之家其它相关文章!

相关文章

  • 前端利用jsencrypt.js进行RSA加密示例详解

    前端利用jsencrypt.js进行RSA加密示例详解

    这篇文章主要为大家介绍了前端利用jsencrypt.js进行RSA加密示例详解,有需要的朋友可以借鉴参考下,希望能够有所帮助,祝大家多多进步,早日升职加薪
    2023-08-08
  • 微信小程序 循环及嵌套循环的使用总结

    微信小程序 循环及嵌套循环的使用总结

    这篇文章主要介绍了微信小程序 循环及嵌套循环的使用总结的相关资料,希望通过本文能帮助到大家,需要的朋友可以参考下
    2017-09-09
  • JS前端面试手写apply和bind实例

    JS前端面试手写apply和bind实例

    这篇文章主要为大家介绍了JS前端面试手写apply和bind实例的轻松实现详解,有需要的朋友可以借鉴参考下,希望能够有所帮助,祝大家多多进步,早日升职加薪
    2022-12-12
  • 前端必会的package.json创建及常见属性用法示例详解

    前端必会的package.json创建及常见属性用法示例详解

    这篇文章主要为大家介绍了前端必会的package.json创建及常见属性用法示例详解,有需要的朋友可以借鉴参考下,希望能够有所帮助,祝大家多多进步,早日升职加薪
    2023-08-08
  • JavaScript 键盘事件的处理及属性详解

    JavaScript 键盘事件的处理及属性详解

    这篇文章主要为大家介绍了JavaScript 键盘事件的处理及属性详解,有需要的朋友可以借鉴参考下,希望能够有所帮助,祝大家多多进步,早日升职加薪
    2023-01-01
  • 详解JS前端使用迭代器和生成器原理及示例

    详解JS前端使用迭代器和生成器原理及示例

    这篇文章主要为大家介绍了详解JS前端使用迭代器和生成器原理及示例,有需要的朋友可以借鉴参考下,希望能够有所帮助,祝大家多多进步,早日升职加薪
    2023-02-02
  • CryptoJs常规密码加密demo

    CryptoJs常规密码加密demo

    这篇文章主要为大家介绍了CryptoJs常规密码加密的实现demo,有需要的朋友可以借鉴参考下,希望能够有所帮助,祝大家多多进步,早日升职加薪
    2023-06-06
  • JavaScript实现文本转换为文件示例详解

    JavaScript实现文本转换为文件示例详解

    这篇文章主要为大家介绍了JavaScript实现文本转换为文件示例详解,有需要的朋友可以借鉴参考下,希望能够有所帮助,祝大家多多进步,早日升职加薪
    2022-08-08
  • JS图形编辑器实现标尺功能示例详解

    JS图形编辑器实现标尺功能示例详解

    这篇文章主要为大家介绍了JS图形编辑器实现标尺功能示例详解,有需要的朋友可以借鉴参考下,希望能够有所帮助,祝大家多多进步,早日升职加薪
    2023-01-01
  • JavaScript 运行机制详解再浅谈Event Loop

    JavaScript 运行机制详解再浅谈Event Loop

    这篇文章主要介绍了JavaScript 运行机制详解及浅谈了Event Loop,感兴趣的小伙伴可以和小编一起阅读下面文章的具体内容
    2021-09-09

最新评论