刷爆leetcode第十二期 0026 数组中数字出现的次数
创始人
2024-01-13 02:02:06

编号0026 数组中数字出现的次数

一个整型数组 nums 里除两个数字之外,其他数字都出现了两次。请写程序找出这两个只出现一次的数字。要求时间复杂度是O(n),空间复杂度是O(1)。

题目示例如下

在这里插入图片描述

这里其实是一道我一个月之前做的题目

在学弟的博客里刚好看到了 又翻了翻自己的博客 好像没有这道题目的题解

刚看到第一眼还以为自己不会了 慢慢梳理了下思路

这里其实又很多种做法 排序之后对比前后数字啊

使用一个很大的数组将它们依次赋值给数组里面对应的值啦

当然这里最优的解法应该是异或法

我们想想看将整个数组里面所有的元素异或 是不是就能得到那两个不同数字的异或了

(因为相同的数字异或都变成0了)

那么首先 我们可以将整个数组异或下来得到一个数字

就像这样

    //首先使用一个测试数字0  让他一一和数组里面的异或 //异或完毕之后就会只剩下两个数字的异或结果int test = 0;int i = 0;for(i=0;itest^=nums[i];}

之后得到这个结果了之后怎么办呢?

我们之后要将整个数组分成两个 尤其是这两个不同的数字要在不同的组别中

那么要怎么分呢?

这也是这个题目唯一的难点

我们可以利用 ‘位’ 来分组

我们都知道了 test是这两个数字异或的结果

那么说明了什么呢?

是不是这个数字的二进制中为1的位 一定是这两个数的位不同的

仔细思考下异或的性质

那么想明白这个事情之后就简单了

我们开始利用这个性质分组

首先找出不同的位在哪里(1)

// 之后我们可以将这个数组分成两个 (这其中两个数字要不在同一个地方)// 这两个数字异或结果为1的地方一定是不相等的  // 所以我们首先要找出第一个出现1的地方// 我们使用count来计数这个1出现的地方int count =0;for(i=0;i<32;i++){if((test>>i)&1==1){break;}count++;}

再之后分别异或下就可以了

    // 之后我们用count将数组分组 分别异或两个数得到的就是两个数了int num1 = test;int num2 = test;for(i=0;iif((nums[i]>>count)&1 == 1){num1^=nums[i];}else{num2^=nums[i];}}//存放到动态数组里面int* a = (int*)malloc(sizeof(int)*2);a[0]=num1;a[1]=num2;// 最后设定下返回数组的大小就可以*returnSize = 2;return a;
}

整体代码表示如下

/*** Note: The returned array must be malloced, assume caller calls free().*/
int* singleNumbers(int* nums, int numsSize, int* returnSize)
{//首先使用一个测试数字0  让他一一和数组里面的异或 //异或完毕之后就会只剩下两个数字的异或结果int test = 0;int i = 0;for(i=0;itest^=nums[i];}// 之后我们可以将这个数组分成两个 (这其中两个数字要不在同一个地方)// 这两个数字异或结果为1的地方一定是不相等的  // 所以我们首先要找出第一个出现1的地方// 我们使用count来计数这个1出现的地方int count =0;for(i=0;i<32;i++){if((test>>i)&1==1){break;}count++;}// 之后我们用count将数组分组 分别异或两个数得到的就是两个数了int num1 = test;int num2 = test;for(i=0;iif((nums[i]>>count)&1 == 1){num1^=nums[i];}else{num2^=nums[i];}}//存放到动态数组里面int* a = (int*)malloc(sizeof(int)*2);a[0]=num1;a[1]=num2;// 最后设定下返回数组的大小就可以*returnSize = 2;return a;
}

总的来说还是很开心的! 一个月前死活想不出来的题目现在看一眼有思路 十分钟就可以敲出来了

继续加油!

相关内容

热门资讯

demo什么意思 demo版本... 618快到了,各位的小金库大概也在准备开闸放水了吧。没有小金库的,也该向老婆撒娇卖萌服个软了,一切只...
猫咪吃了塑料袋怎么办 猫咪误食... 你知道吗?塑料袋放久了会长猫哦!要说猫咪对塑料袋的喜爱程度完完全全可以媲美纸箱家里只要一有塑料袋的响...
北京的名胜古迹 北京最著名的景... 北京从元代开始,逐渐走上帝国首都的道路,先是成为大辽朝五大首都之一的南京城,随着金灭辽,金代从海陵王...
苗族的传统节日 贵州苗族节日有... 【岜沙苗族芦笙节】岜沙,苗语叫“分送”,距从江县城7.5公里,是世界上最崇拜树木并以树为神的枪手部落...
世界上最漂亮的人 世界上最漂亮... 此前在某网上,选出了全球265万颜值姣好的女性。从这些数量庞大的女性群体中,人们投票选出了心目中最美...
长白山自助游攻略 吉林长白山游... 昨天介绍了西坡的景点详细请看链接:一个人的旅行,据说能看到长白山天池全凭运气,您的运气如何?今日介绍...
应用未安装解决办法 平板应用未... ---IT小技术,每天Get一个小技能!一、前言描述苹果IPad2居然不能安装怎么办?与此IPad不...
脚上的穴位图 脚面经络图对应的... 人体穴位作用图解大全更清晰直观的标注了各个人体穴位的作用,包括头部穴位图、胸部穴位图、背部穴位图、胳...
阿西吧是什么意思 阿西吧相当于... 即使你没有受到过任何外语培训,你也懂四国语言。汉语:你好英语:Shit韩语:阿西吧(아,씨발! )日...
demo什么意思 demo版本... 618快到了,各位的小金库大概也在准备开闸放水了吧。没有小金库的,也该向老婆撒娇卖萌服个软了,一切只...
北京的名胜古迹 北京最著名的景... 北京从元代开始,逐渐走上帝国首都的道路,先是成为大辽朝五大首都之一的南京城,随着金灭辽,金代从海陵王...
苗族的传统节日 贵州苗族节日有... 【岜沙苗族芦笙节】岜沙,苗语叫“分送”,距从江县城7.5公里,是世界上最崇拜树木并以树为神的枪手部落...
猫咪吃了塑料袋怎么办 猫咪误食... 你知道吗?塑料袋放久了会长猫哦!要说猫咪对塑料袋的喜爱程度完完全全可以媲美纸箱家里只要一有塑料袋的响...
长白山自助游攻略 吉林长白山游... 昨天介绍了西坡的景点详细请看链接:一个人的旅行,据说能看到长白山天池全凭运气,您的运气如何?今日介绍...
应用未安装解决办法 平板应用未... ---IT小技术,每天Get一个小技能!一、前言描述苹果IPad2居然不能安装怎么办?与此IPad不...
阿西吧是什么意思 阿西吧相当于... 即使你没有受到过任何外语培训,你也懂四国语言。汉语:你好英语:Shit韩语:阿西吧(아,씨발! )日...
脚上的穴位图 脚面经络图对应的... 人体穴位作用图解大全更清晰直观的标注了各个人体穴位的作用,包括头部穴位图、胸部穴位图、背部穴位图、胳...
demo什么意思 demo版本... 618快到了,各位的小金库大概也在准备开闸放水了吧。没有小金库的,也该向老婆撒娇卖萌服个软了,一切只...
世界上最漂亮的人 世界上最漂亮... 此前在某网上,选出了全球265万颜值姣好的女性。从这些数量庞大的女性群体中,人们投票选出了心目中最美...