【剑斩OFFER】算法的暴力美学——只出现一次的数字 ||

一、题目描述

二、算法原理

我们由题目可得出:3n + 1 个数字,n 表示出现3次数字的类别。

那么我们可以得出3n个数字和只出现1次的数字的每个比特位4种情况:

我们只要得出某个比特位,就能得出32个比特位的,所以这里我们先看其中的一个比特位:

3n个0 + 0 = 0

3n个0 + 1 = 1

3n个1 + 0 =3n

3n个1 + 1 =3n + 1

其中加号的左边是所有出现3次的数字某个比特位的情况,右边是只出现1次的数字的的某个比特位。

最后把 = 号后面的数字 % 3 就是只出现的1次数字的某个比特位,注意:是其中上面四种情况的某一种。

三、代码实现

cpp 复制代码
class Solution {
public:
    int singleNumber(vector<int>& nums) {
        int ret = 0;//表示正确答案
        for(int i = 0; i < 32 ; i++)
        {
            int sum = 0;//表示 ret 第 i 位比特位的和
            for(auto e : nums)
            {
                if(((1 << i) & e) != 0) sum++;
            }
            if((sum % 3) == 1) ret = (1 << i) | ret;
        }
        return ret;
    }
};

另外一种解法:

cpp 复制代码
class Solution {
public:
    int singleNumber(vector<int>& nums) {
        sort(nums.begin(), nums.end());
        int unsame;
        for (int i = 0; i < nums.size(); i++)
        {
            if ( i != nums.size()- 1 && nums[i] == nums[i+1]) i += 2;
            else
            {
                unsame =  nums[i];
                break;
            }
        }
        return unsame;
    }
};
相关推荐
无极低码2 小时前
ecGlypher新手安装分步指南(标准化流程)
人工智能·算法·自然语言处理·大模型·rag
软件算法开发2 小时前
基于海象优化算法的LSTM网络模型(WOA-LSTM)的一维时间序列预测matlab仿真
算法·matlab·lstm·一维时间序列预测·woa-lstm·海象优化
superior tigre3 小时前
22 括号生成
算法·深度优先
努力也学不会java4 小时前
【缓存算法】一篇文章带你彻底搞懂面试高频题LRU/LFU
java·数据结构·人工智能·算法·缓存·面试
旖-旎4 小时前
二分查找(x的平方根)(4)
c++·算法·二分查找·力扣·双指针
ECT-OS-JiuHuaShan5 小时前
朱梁万有递归元定理,重构《易经》
算法·重构
智者知已应修善业5 小时前
【51单片机独立按键控制数码管移动反向,2片74CH573/74CH273段和位,按键按下保持原状态】2023-3-25
经验分享·笔记·单片机·嵌入式硬件·算法·51单片机
khddvbe6 小时前
C++并发编程中的死锁避免
开发语言·c++·算法
C羊驼6 小时前
C语言:两天打鱼,三天晒网
c语言·经验分享·笔记·算法·青少年编程
菜菜小狗的学习笔记6 小时前
剑指Offer算法题(四)链表
数据结构·算法·链表