Single Number位运算基础问题--力扣101算法题解笔记

10.2Single Number位运算基础问题

题目描述

给定一个整数数组,这个数组里只有一个数字出现了一次,其余数字出现了两次,求这个只出现一次的数字。

输入输出样例

Input :[4, 1, 2, 1, 2]

Output:4

输入一个一维整数数组,输出是该数组内的一个整数

题解

我们可以利用x^x = 0 和x ^ 0 = x 的特点,将数组内所有的数字进行按位异或。出现两次的所有数字按位异或的结果是0,0与出现一次的数字亦或可以得到这个数字本身。

cpp 复制代码
#include <iostream>
#include <vector>
using namespace std;

int sigleNumber(vector<int>& nums) {
        int ans = 0;
        for (const int& num : nums) {
                ans = ans ^ num;
        }
        return ans;
}

int main() {
        vector<int> ans = { 4,1,2,1,2 };

        cout << sigleNumber(ans) << endl;

        return 0;
}
相关推荐
CoderCodingNo6 小时前
【NOIP】2011真题解析 luogu-P1003 铺地毯 | GESP三、四级以上可练习
算法
iFlyCai6 小时前
C语言中的指针
c语言·数据结构·算法
查古穆6 小时前
栈-有效的括号
java·数据结构·算法
再一次等风来6 小时前
近场声全息(NAH)仿真实现:从阵列实值信号到波数域重建
算法·matlab·信号处理·近场声全息·nah
汀、人工智能6 小时前
16 - 高级特性
数据结构·算法·数据库架构·图论·16 - 高级特性
大熊背6 小时前
利用ISP离线模式进行分块LSC校正的方法
人工智能·算法·机器学习
XWalnut7 小时前
LeetCode刷题 day4
算法·leetcode·职场和发展
蒸汽求职7 小时前
机器人软件工程(Robotics SDE):特斯拉Optimus落地引发的嵌入式C++与感知算法人才抢夺战
大数据·c++·算法·职场和发展·机器人·求职招聘·ai-native
AI成长日志7 小时前
【笔面试算法学习专栏】双指针专题·简单难度两题精讲:167.两数之和II、283.移动零
学习·算法·面试
旖-旎8 小时前
分治(库存管理|||)(4)
c++·算法·leetcode·排序算法·快速选择算法