【C++算法】34.位运算_丢失的数字

文章目录


题目链接:

268. 丢失的数字


题目描述:


解法

  1. 哈希表

    创建一个0~5的数组

    从前往后遍历一下,有的数字就在表里面标记一下,最后看一下哪些数字没有被标记过。

  2. 高斯求和

    先求出应该有的和:(首项+末项)*项数÷2

    然后减去数组的和

  3. 位运算(异或运算的运算律)

    1. a^0=a
    2. a^a=0
    3. a^b^c=a^(b^c)

    原始数组:nums:[0,1,3,5,4]

    0~50 1 2 3 4 5

    然后把一堆数异或在一起


C++ 算法代码:

cpp 复制代码
class Solution 
{
    public:
    int missingNumber(vector<int>& nums) 
    {
        int ret = 0;
        for(auto x : nums) ret ^= x;
        for(int i = 0; i <= nums.size(); i++) ret ^= i;
        return ret;
    }
};
相关推荐
QQ4022054968 小时前
Python+django+vue3预制菜半成品配菜平台
开发语言·python·django
遥遥江上月8 小时前
Node.js + Stagehand + Python 部署
开发语言·python·node.js
蜡笔小马9 小时前
21.Boost.Geometry disjoint、distance、envelope、equals、expand和for_each算法接口详解
c++·算法·boost
m0_531237179 小时前
C语言-数组练习进阶
c语言·开发语言·算法
超级大福宝9 小时前
N皇后问题:经典回溯算法的一些分析
数据结构·c++·算法·leetcode
Wect9 小时前
LeetCode 530. 二叉搜索树的最小绝对差:两种解法详解(迭代+递归)
前端·算法·typescript
Rabbit_QL9 小时前
【BPE实战】从零实现 BPE 分词器:训练、编码与解码
python·算法·nlp
Railshiqian9 小时前
给android源码下的模拟器添加两个后排屏的修改
android·开发语言·javascript
小O的算法实验室9 小时前
2024年IEEE TII SCI1区TOP,面向动态多目标多AUV路径规划的协同进化计算算法,深度解析+性能实测
算法·论文复现·智能算法·智能算法改进
Charlie_lll9 小时前
力扣解题-88. 合并两个有序数组
后端·算法·leetcode