首页 > 其他 > 详细

136#只出现一次的数字

时间:2019-09-03 16:42:20      阅读:85      评论:0      收藏:0      [点我收藏+]
给定一个非空整数数组,除了某个元素只出现一次以外,其余每个元素均出现两次。找出那个只出现了一次的元素。
说明:
你的算法应该具有线性时间复杂度。 你可以不使用额外空间来实现吗?
示例 1:
输入: [2,2,1]
输出: 1

示例 2:
输入: [4,1,2,1,2]
输出: 4
来源:力扣(LeetCode)
 
 
 
非常有趣的一道题,解法很多
解法一:  (a+b+c)*2-(a+a+b+b+c)=c
解法二:  哈希表     遍历,查找表中是否有该元素的键,有则删除,无则加入,最后剩下的就是答案
解法三:异或操作    0^a=a     a^a=0
 
public int singleNumber(int[] nums) {
        int result = 0;
        for (int i = 0; i < nums.length; i++) {
			result = result^nums[i];
		}
        return result;
    }

  

 

136#只出现一次的数字

原文:https://www.cnblogs.com/duanzhiwei/p/11453807.html

(0)
(0)
   
举报
评论 一句话评论(0
关于我们 - 联系我们 - 留言反馈 - 联系我们:wmxa8@hotmail.com
© 2014 bubuko.com 版权所有
打开技术之扣,分享程序人生!