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;
}
相关推荐
YL200404265 小时前
048路径总和III
数据结构·dfs
z200509305 小时前
每日简单算法题——————跟着卡尔
算法
️是786 小时前
信息奥赛一本通—编程启蒙(3395:练68.3 车牌问题)
数据结构·c++·算法
Liangwei Lin7 小时前
LeetCode 118. 杨辉三角
算法·leetcode·职场和发展
计算机安禾7 小时前
【c++面向对象编程】第24篇:类型转换运算符:自定义隐式转换与explicit
java·c++·算法
鼠鼠我(‘-ωก̀ )好困7 小时前
leetGPU
算法
我星期八休息7 小时前
Linux系统编程—基础IO
linux·运维·服务器·c语言·c++·人工智能·算法
池塘的蜗牛7 小时前
A Low-Complexity Method for FFT-based OFDM Sensing
算法
故事和你918 小时前
洛谷-【图论2-1】树5
开发语言·数据结构·c++·算法·动态规划·图论
咖啡里的茶i8 小时前
视觉显著目标的自适应分割与动态网格生成算法研究
人工智能·算法·目标跟踪