定个小目标之每天刷LeetCode热题(12)

这是一道简单题,使用位运算中的异或运算即可,异或运算有以下性质:

1、任何数异或 0 结果仍然是原来的数,即 a⊕0=a

2、任何数和其自身做异或运算,结果是 0

所以我们只需要让数组里的所有元素进行异或运算得到的结果就是那个只出现一次的数字,代码如下所示

java 复制代码
class Solution {
    public int singleNumber(int[] nums) {
        int single = 0;
        for (int num : nums) {
            single ^= num;
        }
        return single;
    }
}

题目链接:题单 - 力扣(LeetCode)全球极客挚爱的技术成长平台

相关推荐
xu_yule10 小时前
算法基础(数论)—算法基本定理
c++·算法·算数基本定理
CoderCodingNo10 小时前
【GESP】C++五级真题(结构体排序考点) luogu-B3968 [GESP202403 五级] 成绩排序
开发语言·c++·算法
YGGP12 小时前
【Golang】LeetCode 32. 最长有效括号
算法·leetcode
自然常数e12 小时前
字符函数和字符串函数
c语言·算法·visual studio
leaves falling12 小时前
c语言分数求和
算法
Das112 小时前
【机器学习】01_模型选择与评估
人工智能·算法·机器学习
星轨初途13 小时前
郑州轻工业大学2025天梯赛解题
c++·经验分享·笔记·算法·链表·剪枝
不忘不弃13 小时前
从字符串中提取数字
数据结构·算法
囊中之锥.14 小时前
《机器学习SVM从零到精通:图解最优超平面与软间隔实战》
算法·机器学习·支持向量机