【剑指offer】面试题56:数组中数字出现的次数【C++版本】

博客围绕剑指Offer中‘数组中只出现一次的两个数字’题目展开。题目要求在整形数组中找出只出现一次的两个数字,需满足时间复杂度O(n)、空间复杂度O(1)。解题思路是利用异或特性,将所有数异或消除偶数次数字,再分组异或得出结果,还给出了C++版本可AC的解法。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

总结的部分题目思路与代码,待完善。
【剑指offer-第二版】部分题目与解答【C++版本】

题目:

数组中只出现一次的两个数字

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

解题思路:

1.注意到时间复杂度是O(n)而空间复杂度是O(1)。
2.看到这种出现偶数次数的情况,都可以考虑使用异或进行解答,因为一个数异或它本身为0。
3.全部数异或之后能够消除掉出现偶数次数的数字,结果为出现一次的两个数字的异或结果。这个结果必然有一位不等于0,可以根据不等于0的这位把所有数字分成两组,则每组各包含一个出现一次的数字。此时对两组数据分别进行异或,两个结果就是最后的两个数字。

可以AC的解法【C++版本】

#include <vector>
#include <iostream>
using namespace std;
void FindNumsAppearOnce(vector<int> data, int* num1, int *num2);
int main() {
       vector<int> data{ 1,1,2,2,3,4,4,5,5,6,6,7 };
       int num1, num2;
       FindNumsAppearOnce(data, &num1, &num2);
       cout << num1 << endl;
       cout << num2 << endl;
       system("pause");
       return 0;
}
void FindNumsAppearOnce(vector<int> data, int* num1, int *num2) {
       if (data.size() < 2)return;
       *num1 = *num2 = 0;
       int tmp = 0;
       for (auto a : data) {
              tmp = tmp ^ a;
       }
       if (tmp == 0)return;
       int posi = 0;
       //这里进行一个判断,即posi的大小不能大于int的位数大小
       while (posi < 8*sizeof(int)) {
              if (tmp & 0x1) {
                     break;
              }
              tmp = tmp >> 1;
              posi++;
       }
       int scale = 1 << posi;
       for (auto a : data) {
              if (a & scale) {
                     *num1 = (*num1) ^ a;
              }
              else {
                     *num2 = (*num2) ^ a;
              }
       }
}
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值