LeetCode-数组篇

技术LeetCode-数组篇 LeetCode-数组篇1.只出现一次的数字
难度:简单
给定一个非空整数数组,除了某个元素只出现一次以外,其余每个元素均出现两次。找出那个只出现了一次的元素。
说明:

LeetCode-数组章节

1.只出现一次的数字

难度:简单

给定一个非空整数数组,除了一个元素外,每个元素都会出现两次。找到只出现一次的元素。

描述:

您的算法应该具有线性时间复杂度。你能在不占用额外空间的情况下做到吗?

例1:

输入: [2,2,1]

输出: 1

例2:

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

输出: 4

解决方案思路:

这个问题有很多解决方案,但是这个问题不需要额外的空间。最简单的方法就是用异或运算求解。

异或运算满足三个性质:

记住这三个性质是解决找重复问题的关键。

解决方案类{

public int single number(int[]nums){ 0

int结果=0;

//遍历数组中的每个数字,进行异或运算。

for(int num : nums){ 0

结果^=小水;

}

返回结果;

}

}

/**

时间复杂度:O(n)遍历的数组长度

复杂性:O(1)不需要额外的空间。

*/

2.多次元素

难度:简单

给定一个n大小的数组,找出它的大部分元素。大多数元素都出现在数组中。n/2?元素。

您可以假设数组是非空的,并且在给定的数组中总是有许多元素。

例1:

输入:[3,2,3]

产出:3

例2:

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

产出:2

解决方案思路:

借助哈希表统计数组中每个数字的个数,然后进行相应的业务处理。

解决方案类{

public int MajorityElEMENT(int[]nums){ 0

//先扔进自定义方法,计算数组中每个数字的个数。

映射整数,整数计数=个数(个数);

//遍历地图,找到数字最大的数字。

地图。EntryInteger,Integer majorityEntry=null

(地图。EntryInteger,整数条目:计数. entryset()){ 0

if(majority entry==null | | entry . getvalue(). majority entry . getvalue()){ 0

majorityEntry=entry

}

}

返回MajorityEntry . GetKey();

}

//使用哈希表

//自定义计算数组数量的方法。

私有映射整数,整数计数(int[]nums){ 0

MapInteger,Integer计数=新HashMapInteger,Integer();

for(int num : nums){ 0

if(!counts . Contains KeY(num)){ 0

//没有,就加一个新的。

counts.put(num,1);

} else {

//有就拿出来加一个。

counts.put(num,counts . get(num)1);

}

}

返回计数;

}

}

/**

时间复杂度:O(n)遍历数组。

空间复杂度:O(n)通过哈希表记录出现的数字个数。

*/

内容来源网络,如有侵权,联系删除,本文地址:https://www.230890.com/zhan/154015.html

(0)

相关推荐

  • Hibernate3有哪些新特性

    技术Hibernate3有哪些新特性小编给大家分享一下Hibernate3有哪些新特性,相信大部分人都还不怎么了解,因此分享这篇文章给大家参考一下,希望大家阅读完这篇文章后大有收获,下面让我们一起去了解一下吧!Hiber

    攻略 2021年12月8日
  • C#的二次开发及应用举例分析

    技术C#的二次开发及应用举例分析本篇内容主要讲解“C#的二次开发及应用举例分析”,感兴趣的朋友不妨来看看。本文介绍的方法操作简单快捷,实用性强。下面就让小编来带大家学习“C#的二次开发及应用举例分析”吧!二次开发及应用

    攻略 2021年11月26日
  • C++中为什么不要在一条语句内声明类或枚举值的同时又定义该类型的变量

    技术C++中为什么不要在一条语句内声明类或枚举值的同时又定义该类型的变量这篇文章主要讲解了“C++中为什么不要在一条语句内声明类或枚举值的同时又定义该类型的变量”,文中的讲解内容简单清晰,易于学习与理解,下面请大家跟着小

    攻略 2021年11月29日
  • 快速建站选择台湾云服务器有什么好处

    技术快速建站选择台湾云服务器有什么好处很多新站长对于租用服务器应该选择什么样的海外服务器还是比较困惑的,尤其是目前市面上的除了物理服务器、云服务器、VPS的平台区别之外,对于哪个地区的机房更合适也有不了解的地方,就最近各

    礼包 2021年10月30日
  • Oracle11g RAC下ASM的管理和维护方法有哪些?

    技术Oracle11g RAC下ASM的管理与维护方法是什么这篇文章主要介绍“Oracle11g RAC下ASM的管理与维护方法是什么”,在日常操作中,相信很多人在Oracle11g RAC下ASM的管理与维护方法是什么

    攻略 2021年12月22日
  • Apache Hudi使用是怎么样的

    技术Apache Hudi使用是怎么样的Apache Hudi使用是怎么样的,相信很多没有经验的人对此束手无策,为此本文总结了问题出现的原因和解决方法,通过这篇文章希望你能解决这个问题。]数据实时处理和实时的数据实时分为

    攻略 2021年11月23日