前端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算法只出现一次数字的资料请关注脚本之家其它相关文章!

相关文章

  • 微信小程序 高德地图SDK详解及简单实例(源码下载)

    微信小程序 高德地图SDK详解及简单实例(源码下载)

    这篇文章主要介绍了微信小程序 高德地图详解及简单实例(源码下载)的相关资料,需要的朋友可以参考下
    2017-01-01
  • JavaScript对象(详细)

    JavaScript对象(详细)

    这篇文章主要介绍了Java中的Script对象的相关资料,需要的朋友可以参考下文章里内容
    2021-08-08
  • autojs使用intent发送邮件带附件实现示例

    autojs使用intent发送邮件带附件实现示例

    这篇文章主要为大家介绍了autojs使用intent发送邮件带附件实现示例详解,有需要的朋友可以借鉴参考下,希望能够有所帮助,祝大家多多进步,早日升职加薪
    2023-01-01
  • delete 语法的本质深入解析

    delete 语法的本质深入解析

    这篇文章主要为大家介绍了delete 语法的本质深入解析,有需要的朋友可以借鉴参考下,希望能够有所帮助,祝大家多多进步,早日升职加薪
    2023-03-03
  • JSON与JS对象的区别与对比

    JSON与JS对象的区别与对比

    JSON是什么?JSON是JS的一种简单数据格式,JSON是JavaScript原生格式,它是一种严格的js对象的格式,JSON的属性名必须有双引号,如果值是字符串,也必须是双引号
    2017-03-03
  • 微信小程序图片宽100%显示并且不变形

    微信小程序图片宽100%显示并且不变形

    这篇文章主要介绍了微信小程序图片宽100%显示并且不变形的相关资料,需要的朋友可以参考下
    2017-06-06
  • 微信小程序 视图容器组件的详解及实例代码

    微信小程序 视图容器组件的详解及实例代码

    这篇文章主要介绍了微信小程序 视图容器组件的详解及实例代码的相关资料,这里对基础知识进行了详细介绍并附有简单实例代码,需要的朋友可以参考下
    2017-01-01
  • JavaScript Dom对象的操作

    JavaScript Dom对象的操作

    这篇文章主要介绍了JavaScript Dom对象的操作,文张以浏览器网页就是一个Dom树形结构做为核心,然后根据核心进行更新Dom节点、获得Dom节点、删除一个Dom节点、添加一个新的节点操作,下面文章是详细内容,需要的朋友可以参考以下
    2021-11-11
  • AngularJS 表达式详细讲解及实例代码

    AngularJS 表达式详细讲解及实例代码

    本文主要介绍AngularJS 表达式,这里对AngularJS 表达式详细介绍和实例代码,有需要的小伙伴可以参考下
    2016-07-07
  • 微信小程序 form组件详解及简单实例

    微信小程序 form组件详解及简单实例

    这篇文章主要介绍了微信小程序 form组件详解及简单实例的相关资料,需要的朋友可以参考下
    2017-01-01

最新评论