【剑斩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;
    }
};
相关推荐
肆悟先生3 分钟前
3.15 引用类型
c++·算法
暗之星瞳9 分钟前
随机森林(初步学习)
算法·随机森林·机器学习
不爱吃糖的程序媛11 分钟前
基于Ascend C开发的Vector算子模板库-ATVOSS 技术深度解读
人工智能·算法·机器学习
松涛和鸣11 分钟前
35、Linux IPC进阶:信号与System V共享内存
linux·运维·服务器·数据库·算法·list
Cx330❀17 分钟前
《C++ 动态规划》第001-002题:第N个泰波拉契数,三步问题
开发语言·c++·算法·动态规划
LYFlied17 分钟前
【每日算法】LeetCode 114. 二叉树展开为链表:从树结构到线性结构的优雅转换
数据结构·算法·leetcode·链表·面试·职场和发展
毕设源码-钟学长22 分钟前
【开题答辩全过程】以 基于Spark机器学习算法的体育新闻智能分类系统设计与实现为例,包含答辩的问题和答案
算法·机器学习·spark
天勤量化大唯粉25 分钟前
基于距离的配对交易策略:捕捉价差异常偏离的均值回归机会(天勤量化代码实现)
android·开发语言·python·算法·kotlin·开源软件·策略模式
智航GIS26 分钟前
ArcGIS大师之路500技---036通俗易懂讲解克里金法
人工智能·算法·arcgis
拼好饭和她皆失27 分钟前
逆元,除法同余原理
算法·逆元·除法同余原理