【刷题】只出现一次的数字(三种解法)

【刷题】只出现一次的数字


文章目录

  • 【刷题】只出现一次的数字
    • 解法
      • 异或运算
      • 解法一 : 异或运算
      • 解法二:集合类
        • Set集合
        • Map集合

链接:

https://www.nowcoder.com/share/jump/2008263481696810321082

https://leetcode.cn/problems/single-number/description/

题目描述

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

解法

在使用异或运算解题之前,我们先介绍一下异或运算,并会在使用异或运算解问题之后总结分别利用到了 **异或运算 ** 怎样的性质?

(如果你对异或运算很了解,可以直接跳过 异或运算 的讲解,看其他的解法)

异或运算

  • 什么是异或运算?

    1.异或运算是位运算 (参与位运算的对象是二进制)

    2.异或运算相当于 “无进位相加” ,即 二进制相加不进位

  • 定义

    两个参与运算的对象,对两对象进行 异或运算

  • 运算规则

0^0=0   0^1=1   1^0=1  1^1=0 
  • 总结

    参与运算的两个对象,如果相同则为0,相异则为1

  • 性质

    任意x与0异或都为x : x^0 = x

    任意x与x异或都为0 : x^x = 0

  • 用途

    1.翻转指定位

    例如 : 翻转10100011 的后3位,翻转结果为10100100

    10100011 ^ 00000111 = 10100100
    

在这里插入图片描述

  1. 任何数与0异或值不变

例如 : 10101010 ^ 00000000 = 10101010

  1. 交换两数
public void swap(int a,int b){if (a != b){a ^= b;b ^= a;a ^= b;}
}

在这里插入图片描述


解法一 : 异或运算

思路 :
遍历数组,对所有的元素进行 异或运算

代码:

public int singleNumber (int[] nums) {int temp = 0;for(int i = 0;i < nums.length;i++){temp ^= nums[i];}return temp;}

解释 : 我们在这里都使用到了 关于异或运算 怎么样的性质呢 ?

由于数组中只有一个元素只出现一遍,其余的元素都出现两遍 , 那么我们在对所有元素相异或的时候,会出现这样的现象 x^x = 0, 0^x = x ; 这样之后,当全部元素都相异或之后,temp保存的值就是只出现一遍的元素.


解法二:集合类


Set集合

思路 :

利用Set集合中的contains(K key)方法.

  1. 遍历数组的同时往Set集合中插入当前元素,插入的前提是集合中不存在该元素,即
  • 若该元素在Set中已经存在,则将Set集合中已存在的删除并继续遍历;
  • 若该元素在Set中不存在,则顺利插入并继续遍历
  1. 现在Set集合中就只剩下目标元素temp,通过 迭代Set集合找temp/遍历数组找出Set集合中的temp

代码 :

public int singleNumber(int[] nums) {Set<Integer> set = new HashSet<>();//遍历数组for (int i = 0; i < nums.length; i++) {int key = nums[i];if (set.contains(key)) {set.remove(key);} else {set.add(key);}}//我们这里采用遍历数组获取目标元素for (int i = 0; i < nums.length; i++) {int key = nums[i];if (set.contains(key)) {return key;}}return -1; //没有找到返回-1}

Map集合

思路:

  • 遍历数组的同时把数组中的元素插入到Map集合中担任key的角色

  • 实时更新存入元素key的value值

我这里采用的是Map集合中的getOrDefault(K key,V value) 方法来做

代码 :

 public int singleNumber (int[] nums) {Map<Integer,Integer> map = new HashMap<>();//遍历数组for (int i = 0; i < nums.length; i++) {int key = nums[i];int value =  map.getOrDefault(key,0);map.put(key,value+1);}//迭代Map集合,找到value等于1的keyfor (Map.Entry<Integer,Integer> entrySet:map.entrySet()) {if (entrySet.getValue()==1){return entrySet.getKey();}}return -1;}

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.hqwc.cn/news/129057.html

如若内容造成侵权/违法违规/事实不符,请联系编程知识网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

基于Java的民宿管理系统设计与实现(源码+lw+部署文档+讲解等)(民宿预约、民宿预订、民宿管理、酒店预约通用)

文章目录 前言具体实现截图论文参考详细视频演示代码参考源码获取 前言 &#x1f497;博主介绍&#xff1a;✌全网粉丝10W,CSDN特邀作者、博客专家、CSDN新星计划导师、全栈领域优质创作者&#xff0c;博客之星、掘金/华为云/阿里云/InfoQ等平台优质作者、专注于Java、小程序技…

运行软件找不到mfc140u.dll怎么解决,mfc140u.dll是什么文件

"找不到 mfc140u.dll"是一条错误信息&#xff0c;表示您的计算机上缺少一个名为 mfc140u.dll 的动态链接库&#xff08;DLL&#xff09;文件。这个文件通常与 Microsoft Visual C Redistributable 相关。Mfc140u.dll 是 Microsoft 基础类库&#xff08;MFC&#xff0…

Linux: 基础IO

学习目标 1.C接口与系统调用接口的差别 2.文件描述符, 重定向, 一切皆文件, 缓冲区 3.fd与FILE, 系统调用和库函数的关系 4.系统中的inode 5.软硬链接 6.动静态库 预备知识 1.文件 内容 属性 2.文件的所有操作: a. 对内容的操作 b.对属性的操作 3.文件在磁盘(硬件)上, 我…

Blender 导出 fbx 到虚幻引擎中丢失材质!!!(使用Blender导出内嵌材质的fbx即可解决)

目录 0 引言1 Blender导出内嵌纹理的fbx模型 0 引言 我在Blender处理了一些fbx模型后再次导出到UE中就经常出现&#xff0c;材质空白的情况&#xff08;如下图所示&#xff09;&#xff0c;今天终于找到问题原因&#xff0c;记录下来&#xff0c;让大家避免踩坑。 其实原因很简…

Pikachu靶场——跨站请求伪造(CSRF)

文章目录 1. 跨站请求伪造&#xff08;CSRF&#xff09;1.1 CSRF(get)1.2 CSRF(post)1.3 CSRF Token1.4 CSRF漏洞防御 1. 跨站请求伪造&#xff08;CSRF&#xff09; 还可以参考我的另一篇文章&#xff1a;跨站请求伪造(CSRF) 全称Cross-site request forgery&#xff0c;翻译…

c++day3

1> 思维导图 2> 设计一个Per类&#xff0c;类中包含私有成员:姓名、年龄、指针成员身高、体重&#xff0c;再设计一个Stu类&#xff0c;类中包含私有成员:成绩、Per类对象p1&#xff0c;设计这两个类的构造函数、析构函数和拷贝构造函数。 #include <iostream>us…

竞赛 机器视觉的试卷批改系统 - opencv python 视觉识别

文章目录 0 简介1 项目背景2 项目目的3 系统设计3.1 目标对象3.2 系统架构3.3 软件设计方案 4 图像预处理4.1 灰度二值化4.2 形态学处理4.3 算式提取4.4 倾斜校正4.5 字符分割 5 字符识别5.1 支持向量机原理5.2 基于SVM的字符识别5.3 SVM算法实现 6 算法测试7 系统实现8 最后 0…

Redis之主从复制,哨兵模式,集群

Redis之主从复制&#xff0c;哨兵模式&#xff0c;集群 1、主从复制1.1主从复制概述1.2Redis主从复制作用1.3Redis主从复制流程1.4部署Redis 主从复制 2、哨兵模式2.1哨兵模式原理2.2哨兵模式的作用2.3哨兵模式的结构2.4故障转移机制2.5搭建Redis 哨兵模式 3、Redis集群模式3.1…

监控搭建-Prometheus

监控搭建-Prometheus 1、背景2、目标3、选型4、Prometheus4.1、介绍4.2、架构4.3、构件4.4、运行机制4.5、环境介绍4.6、数据准备4.7、网络策略4.7.1、主机端口放行4.7.2、设备端口放行 4.8、部署4.9、验证4.10、配置 1、背景 随着项目信息化进程的推进&#xff0c;操作系统、…

如何从零开始系统的学习项目管理?

一、项目的概念 根据项目管理协会&#xff08;PMI&#xff09;的定义&#xff0c;项目是指为了创造独特的产品、服务或成果而进行的临时性工作。这意味着项目需要有明确的目标&#xff0c;且不是日常重复性工作。尽管项目是临时性工作&#xff0c;但它所交付的成果可能会持续存…

Redis-04独立功能的实现

1、发布与订阅 介绍&#xff1a; Redis的发布与订阅功能由PUBLISH、SUBSCRIBE、PSUBSCRIBE等命令组成。通过SUBSCRIBE命令&#xff0c;客户端可以订阅一个或多个频道&#xff0c;成为这些频道的订阅者&#xff08;subscriber&#xff09;每当有其他客户端向被订阅的频道发送消…

(一)Apache log4net™ 手册 - 介绍

0、相关概念 Log4j 几乎每个大型应用程序都包含自己的日志记录或跟踪 API。根据这一规则&#xff0c;E.U. SEMPER &#x1f339;项目决定编写自己的跟踪 API。那是在 1996 年初。经过无数次的增强、几个化身和大量的工作&#xff0c;API 已经发展成为 log4j —— 一个流行的 Ja…