leetcode 260,136,137 数字只出现一次

2024-06-02 09:18
文章标签 leetcode 一次 数字 260 136 137

本文主要是介绍leetcode 260,136,137 数字只出现一次,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

leetcode 260. 只出现一次的数字 III  有且只有两个元素只出现一次,其他的元素都是出现两次

leetcode 136. 只出现一次的数字   只有一个元素出现一次,其他元素都是出现两次

leetcode 137. 只出现一次的数字 II  只有一个元素出现一次,其余的元素都是出现三次

数字只出现一次

代码:

 public static void main(String[] args) {
//        int[] arr = {2, 2, 1};
//        int num = singleNumber(arr);
//        System.out.println(num);//        int[] arr={2,1,2,3,4,1};
//        int[] nums = singleNumber2(arr);
//        System.out.println(Arrays.toString(nums));//        int[] arr={2,2,3,2};int[] arr={0,1,0,1,0,1,99};int num = singleNumber3(arr);System.out.println(num);}/*** 只出现一次的数字  其余数字都出现两次,只有一个数字出现一次* 达到只使用线性的时间复杂度  不使用额外的空间* 使用异或运算 相同的元素进行异或运算 为0  0与任何元素异或都是元素本身** @Date: 2020/6/9 23:15* @Author: fuGuoWen* @Return int 返回出现一次的数字* @Throws 无*/public static int singleNumber(int[] nums) {int result = 0;for (int i = 0; i < nums.length; i++) {result ^= nums[i];}return result;}/*** 恰好有两个元素出现一次,其余的元素都是出现两次* 解决方案:* 1.对所有的元素做异或操作* 2.对异或以后的结果取低位第一个为1 的值 temp* 3.对整个元素继续进行遍历,如果当前元素的值与temp 最高位的值相同 返回的值不为0,* 如果当前元素的值与temp 最高位的值不同,返回的是0** 算法 具备 线性的时间复杂度 和常量的空间复杂度** @Date: 2020/6/9 23:28* @Author: fuGuoWen* @Return int[] 整形数组* @Throws 无*/public static int[] singleNumber2(int[] nums) {int result=0;/** 第一步: 所有的元素进行异或,会得到唯一的两个元素的异或值 */for(int i=0;i<nums.length;i++){result^=nums[i];}/** 第二步 获得result低位的第一个不为0 的值 */int temp = 1;while (result != 0) {if ((result & 1) == 1) {break;}temp <<= 1;result >>= 1;}int[] arr=new int[2];for(int i=0;i<nums.length;i++){if((nums[i]&temp)==0){/*** 第三步  对所有的元素进行与最高位的元素的值进行与运算  与最高位元素相同的值 进行的计算不为0* 与最高位元素相同的值 进行的计算结果为0* */arr[0]^=nums[i];}else{arr[1]^=nums[i];}}return arr;}/*** 只有一个元素出现了一次,其他的元素都是出现了三次* 解决思路* 1.* @Date: 2020/6/10 0:26* @Author: fuguowen* @Return* @Throws*/public static int singleNumber3(int[] nums) {/** 第一步  遍历数组的每一位按照二进制位进行累加 */int[] bits = new int[32];for (int i = 0; i < 32; i++) {for (int j = 0; j < nums.length; j++) {bits[i] += (nums[j] & 1);nums[j] >>= 1;}}/*** 第二步 高位元素存储在下标比较大的位置* 从高位元素进行遍历,先进行右移,再进行跟3取模,求余,最后获得元素就是只出现一次的元素* */int result = 0;for (int i = 31; i >= 0; i--) {result <<= 1;result += (bits[i] % 3);}return result;}

 

这篇关于leetcode 260,136,137 数字只出现一次的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/1023557

相关文章

Spring定时任务只执行一次的原因分析与解决方案

《Spring定时任务只执行一次的原因分析与解决方案》在使用Spring的@Scheduled定时任务时,你是否遇到过任务只执行一次,后续不再触发的情况?这种情况可能由多种原因导致,如未启用调度、线程... 目录1. 问题背景2. Spring定时任务的基本用法3. 为什么定时任务只执行一次?3.1 未启用

使用PyTorch实现手写数字识别功能

《使用PyTorch实现手写数字识别功能》在人工智能的世界里,计算机视觉是最具魅力的领域之一,通过PyTorch这一强大的深度学习框架,我们将在经典的MNIST数据集上,见证一个神经网络从零开始学会识... 目录当计算机学会“看”数字搭建开发环境MNIST数据集解析1. 认识手写数字数据库2. 数据预处理的

java字符串数字补齐位数详解

《java字符串数字补齐位数详解》:本文主要介绍java字符串数字补齐位数,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录Java字符串数字补齐位数一、使用String.format()方法二、Apache Commons Lang库方法三、Java 11+的St

Java数字转换工具类NumberUtil的使用

《Java数字转换工具类NumberUtil的使用》NumberUtil是一个功能强大的Java工具类,用于处理数字的各种操作,包括数值运算、格式化、随机数生成和数值判断,下面就来介绍一下Number... 目录一、NumberUtil类概述二、主要功能介绍1. 数值运算2. 格式化3. 数值判断4. 随机

Python判断for循环最后一次的6种方法

《Python判断for循环最后一次的6种方法》在Python中,通常我们不会直接判断for循环是否正在执行最后一次迭代,因为Python的for循环是基于可迭代对象的,它不知道也不关心迭代的内部状态... 目录1.使用enuhttp://www.chinasem.cnmerate()和len()来判断for

电脑多久清理一次灰尘合? 合理清理电脑上灰尘的科普文

《电脑多久清理一次灰尘合?合理清理电脑上灰尘的科普文》聊起电脑清理灰尘这个话题,我可有不少话要说,你知道吗,电脑就像个勤劳的工人,每天不停地为我们服务,但时间一长,它也会“出汗”——也就是积累灰尘,... 灰尘的堆积几乎是所有电脑用户面临的问题。无论你的房间有多干净,或者你的电脑是否安装了灰尘过滤器,灰尘都

哈希leetcode-1

目录 1前言 2.例题  2.1两数之和 2.2判断是否互为字符重排 2.3存在重复元素1 2.4存在重复元素2 2.5字母异位词分组 1前言 哈希表主要是适合于快速查找某个元素(O(1)) 当我们要频繁的查找某个元素,第一哈希表O(1),第二,二分O(log n) 一般可以分为语言自带的容器哈希和用数组模拟的简易哈希。 最简单的比如数组模拟字符存储,只要开26个c

从去中心化到智能化:Web3如何与AI共同塑造数字生态

在数字时代的演进中,Web3和人工智能(AI)正成为塑造未来互联网的两大核心力量。Web3的去中心化理念与AI的智能化技术,正相互交织,共同推动数字生态的变革。本文将探讨Web3与AI的融合如何改变数字世界,并展望这一新兴组合如何重塑我们的在线体验。 Web3的去中心化愿景 Web3代表了互联网的第三代发展,它基于去中心化的区块链技术,旨在创建一个开放、透明且用户主导的数字生态。不同于传统

usaco 1.2 Name That Number(数字字母转化)

巧妙的利用code[b[0]-'A'] 将字符ABC...Z转换为数字 需要注意的是重新开一个数组 c [ ] 存储字符串 应人为的在末尾附上 ‘ \ 0 ’ 详见代码: /*ID: who jayLANG: C++TASK: namenum*/#include<stdio.h>#include<string.h>int main(){FILE *fin = fopen (

leetcode-24Swap Nodes in Pairs

带头结点。 /*** Definition for singly-linked list.* public class ListNode {* int val;* ListNode next;* ListNode(int x) { val = x; }* }*/public class Solution {public ListNode swapPairs(L