数组中只出现一次的数字

本文介绍了一种算法,用于从整型数组中找出仅出现一次的两个数字。通过使用异或运算,该算法能够高效地解决此问题。文章详细阐述了算法步骤,并提供了具体的实现代码。

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

题目描述

一个整型数组里除了两个数字之外,其他的数字都出现了两次。请写程序找出这两个只出现一次的数字。
 
思路:由于性质:a ^ a = 0 ; 0 ^ n = n; 由于数组中有两个数字只出现一次,所以:
1.  将数组中的所有数字 ^,得到的数是这两个数的  ^,
2.  找到两个数 ^ 结果的最后一个1,即为两个数不相同的位
3.根据该位分组,则每一组中只有一个只出现一次的数字。
4.将两个组,分别 ^ ,则分别得到要求的两个数。

代码:

      void FindNumsAppearOnce(vector<int> data,int* num1,int *num2) {
        int len = data.size();
        int num = 0;
        for(int i = 0; i < len;i++)
        {
            num = num^data[i];
        }
        int tmp = 1;
        while((num&tmp) == 0)
        {
            tmp = tmp<<1;
        }
        int arr1[500],arr2[500];
        int id1 =0 ;
        int id2 = 0;
        for(int i = 0; i < len;i++)
        {
            if((data[i] & tmp) == 0)
                (*num1)^=data[i];
            else
                (*num2)^=data[i];
        }
    }

 

转载于:https://www.cnblogs.com/Lune-Qiu/p/9127124.html

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值