乐趣区

关于java:LeetCode136只出现一次的数字

只呈现一次的数字

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

阐明:

你的算法应该具备线性工夫复杂度。你能够不应用额定空间来实现吗?

示例阐明请见 LeetCode 官网。

起源:力扣(LeetCode)
链接:https://leetcode-cn.com/probl…
著作权归领扣网络所有。商业转载请分割官网受权,非商业转载请注明出处。

解法一:二进制运算

利用二进制运算的异或运算操作符 ^,异或运算就是二进制位上雷同地位的数字如果雷同则为 0,如果不同则为 1,即 0^0=0,1^0=1,0^1=1,1^1=0。所以通过遍历一遍数组,把每一个数字进行异或运算,因为反复的数字异或之后都是 0,最初的后果就是只呈现了一次的元素。

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

    public static void main(String[] args) {int[] nums = new int[]{2, 2, 1};
        System.out.println(singleNumber(nums));
    }
}

【每日寄语】 你的累赘将变成礼物,你受的苦将照亮你的路。

退出移动版