首页 > 编程语言 >剑指offer004(Java)-只出现一次的数字(中等)

剑指offer004(Java)-只出现一次的数字(中等)

时间:2023-04-07 12:14:13浏览次数:48  
标签:count map Java nums int res offer004 中等 num

题目:

给你一个整数数组 nums ,除某个元素仅出现 一次 外,其余每个元素都恰出现 三次 。请你找出并返回那个只出现了一次的元素。

示例1:

输入:nums = [2,2,3,2]

输出:3

示例 2:

输入:nums = [0,1,0,1,0,1,100]

输出:100

 

提示:

1 <= nums.length <= 3 * 104
-231 <= nums[i] <= 231 - 1
nums 中,除某个元素仅出现 一次 外,其余每个元素都恰出现 三次
 

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

注意:本题与 力扣 137 题相同:

来源:力扣(LeetCode)
链接:https://leetcode.cn/problems/WGki4K
著作权归领扣网络所有。商业转载请联系官方授权,非商业转载请注明出处。

解题思路:

方法一:位运算

利用int类型固定为32位,利用这32位来统计每一个数值的每一位出现1的次数,然后再对每一位统计出的次数与3进行模运算(如果出现3次,那模运算一定为0),模运算不为0时,就让1向右移动,再与结果进行或运算。

举个例子:[1,1,1,3],1的二进制为 :0001, 3的二进制为:0011

1: 0 0 0 1
1: 0 0 0 1
1: 0 0 0 1
1: 0 0 1 1
c: 0 0 1 4 

当count =4时,count % 3 != 0,res |= (1 << 0) = 0000 | 0001 = 0001

当count = 1时, count % 3 != 0,res |= (1 << 1) = 0001 | 0010 = 0011

当count = 0时, count % 3 = 0,不更新res

...(后面的位都不更新res)

结束时res = 0011 = 3

图片来源:K神老师

代码:

 1 class Solution {
 2     public int singleNumber(int[] nums) {
 3         int res = 0;
 4         //数组中的元素都在int(即 32 位整数)范围
 5         //第一个循环 i从 0~31 ,代表每一位2进制数
 6         for (int i = 0; i < 32; i++){
 7             int count = 0;
 8             for(int num : nums){
 9             // num >> i表示num右移i位置,即把二进制第i位右移到最右边
10             // & 1右移之后与1进行&运算,即得到最右边的数
11             //(num >> i) & 1 举例:num为5,i为2,num二进制为 0101,num>>2&1 = 0001 & 1 = 0001 = 1
12                 count += ((num >> i) & 1);
13             }
14             //count为nums数字中所有数的二进制第i位的和
15             //count%3!=0:目标答案 二进制的第i位为1
16             if (count % 3 != 0){
17                 // 1 << i,将1左移i位,例如i为2,1 << i得到二进制数:100
18                 // 将1左移i位之后,与ans即目标答案进行 | 运算(或运算)
19                // 或 运算的目的就是把 第i位的这个1加到ans里
20                //例如:res = 0 |= 0010 = 0010
21                //继续:res = 0010 |= 0001 = 0011 = 3 
22                 res |= (1 << i);
23             }
24         }
25         return res;
26     }
27 }

方法二:哈希表但空间复杂度和时间复杂度均为O(n)

 1 class Solution {
 2    public int singleNumber(int[] nums) {
 3         HashMap<Integer, Integer> map = new HashMap<>();
 4         for(int num : nums){
 5             map.put(num, map.getOrDefault(num, 0) + 1);
 6         }
 7         for (int num : map.keySet()){
 8             if (map.get(num) == 1) return num; 
 9         }
10         return -1;
11    }
12 }

 

标签:count,map,Java,nums,int,res,offer004,中等,num
From: https://www.cnblogs.com/liu-myu/p/17295737.html

相关文章

  • 织梦CMS粘贴图片自动上传到服务器(Java版)
    ​如何做到ueditor批量上传word图片?1、前端引用代码<!DOCTYPE html PUBLIC "-//W3C//DTDXHTML1.0Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd"><html xmlns="http://www.w3.org/1999/xhtml"><head>......
  • 动易CMS粘贴图片自动上传到服务器(Java版)
    ​ 自动导入Word图片,或者粘贴Word内容时自动上传所有的图片,并且最终保留Word样式,这应该是Web编辑器里面最基本的一个需求功能了。一般情况下我们将Word内容粘贴到Web编辑器(富文本编辑器)中时,编辑器都无法自动上传图片。需要用户手动一张张上传Word图片。如果只有一张图片还能够接......
  • Java serialVersionUID 作用和自动生成设置
    JavaserialVersionUID作用和自动生成设置原文链接:https://blog.csdn.net/plqwf19880902/article/details/129103336一、由来最近在做一个军工的项目,代码提交后,军方用代码安全扫描工具,对代码进行全局扫描,提示一个漏洞,导致原因是实体类实现了Serializable接口,未对serialVer......
  • java简易爬虫Crawler
    这是我的第一个java爬虫,比较简单,没有队列,广度优先算法等,用list集合代替了队列。而且只爬取一个网址上面的图片,并不是将网址中的链接<href>加入队列,然后下载一个网址一个网址下载其中的图片。不过,这是前期的,处于摸索阶段,后期学完队列和广算后,在涉及一点多线程,肯定会比想象中的更......
  • java编程中的C/S模式和B/S模式
    随着社会信息的发展,Java技术已经无处不在,无论是手机软件、手机Java游戏还是电脑软件等,只要你使用到电子产品就会碰到和Java有关的东西,更多的企业正采用Java语言开发网站,越来越多的程序员也应声而起,在学习Java的过程中总会遇到这样或那样的问题,今天千锋小编就大家分享一下在C/S模式......
  • C# javascript中调用自定义函数function
    Default.aspx1<script>2//自定义函数3functionpageInit(){4letdata=[];5varsource_data=my_source_data2();//my_source_data2是一般程序Handler.ashx中,自定义的方法6varmy_data=source_data.split('###');......
  • 力扣1045(MySQL)-买下所有产品的客户(中等)
    题目:Customer 表: Product 表:写一条SQL查询语句,从 Customer 表中查询购买了 Product 表中所有产品的客户的id。示例:  解题思路:建表语句:1createtableifnotexistscustomer_1045(customer_idint(3)notnull,product_keyint(3));2createtableif......
  • Java GenericObjectPool 对象池化技术--SpringBoot sftp 连接池工具类
    JavaBasePooledObjectFactory对象池化技术通常一个对象创建、销毁非常耗时的时候,我们不会频繁的创建和销毁它,而是考虑复用。复用对象的一种做法就是对象池,将创建好的对象放入池中维护起来,下次再用的时候直接拿池中已经创建好的对象继续用,这就是池化的思想。ApacheCommonsPoo......
  • 001-java-markdown语法
    typora中的markdown语法一、标题: 最多支持六级标题文字,或者command+0~6调整标题级别command+/-调整级别一级标题:markdown学习二级标题三级标题四级标题五级标题六级标题 二、字体Hello,world!粗体字:两边加2个**/command+BHello,world!斜体字:两边加1个/comman......
  • Java面向对象继承
    继承的概念继承是面向对象编程中的一个概念,它允许一个类(称为子类或派生类)继承另一个类(称为父类或基类)的属性和方法。子类在继承父类的同时也可以添加自己的属性和方法,从而实现代码的复用和扩展。继承是面向对象编程的三大特征之一,其他两个分别是封装和多态。继承的作用1.提高代码的......