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

相关文章

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

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

哈希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

leetcode-23Merge k Sorted Lists

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

C++ | Leetcode C++题解之第393题UTF-8编码验证

题目: 题解: class Solution {public:static const int MASK1 = 1 << 7;static const int MASK2 = (1 << 7) + (1 << 6);bool isValid(int num) {return (num & MASK2) == MASK1;}int getBytes(int num) {if ((num &

【每日一题】LeetCode 2181.合并零之间的节点(链表、模拟)

【每日一题】LeetCode 2181.合并零之间的节点(链表、模拟) 题目描述 给定一个链表,链表中的每个节点代表一个整数。链表中的整数由 0 分隔开,表示不同的区间。链表的开始和结束节点的值都为 0。任务是将每两个相邻的 0 之间的所有节点合并成一个节点,新节点的值为原区间内所有节点值的和。合并后,需要移除所有的 0,并返回修改后的链表头节点。 思路分析 初始化:创建一个虚拟头节点

C语言 | Leetcode C语言题解之第393题UTF-8编码验证

题目: 题解: static const int MASK1 = 1 << 7;static const int MASK2 = (1 << 7) + (1 << 6);bool isValid(int num) {return (num & MASK2) == MASK1;}int getBytes(int num) {if ((num & MASK1) == 0) {return

【JavaScript】LeetCode:16-20

文章目录 16 无重复字符的最长字串17 找到字符串中所有字母异位词18 和为K的子数组19 滑动窗口最大值20 最小覆盖字串 16 无重复字符的最长字串 滑动窗口 + 哈希表这里用哈希集合Set()实现。左指针i,右指针j,从头遍历数组,若j指针指向的元素不在set中,则加入该元素,否则更新结果res,删除集合中i指针指向的元素,进入下一轮循环。 /*** @param