数据结构与算法《二》

真理只有一个,它不在宗教中,而是在科学中。 ---达芬奇

LeetCode: 只出现一次数字

给定一个非空整数数组,除了某个元素只出现一次以外,其余每个元素均出现两次。找出那个只出现了一次的元素。

说明:

  • 使用线性时间复杂度,不使用额外空间。

示例:

输入: [2,2,1]
输出: 1

分析:

由于对时间复杂度和空间有限制,显然不能进行两次遍历和另开辟空间,这块考察位运算,相同的两个数做异或运算,结果为0,因为数组中除了一个元素只出现一次外,其他元素都出现两次,如果把所有的数都异或,相同的数字异或为0,最后只剩下出现一次的数字,它和0异或,结果就是它本身。

Code:

class Solution {
    public int singleNumber(int[] nums) {
        int num = 0;
        for(int i = 0; i < nums.length; i++){
            num = num ^ nums[i];
        }
        return num;
    }
}

定期分享大数据与知识图谱相关知识点:
微信公众号

posted @ 2019-06-22 11:34  派。  阅读(123)  评论(0编辑  收藏  举报