“缺失数字”的版本间的差异
来自qingwei personal wiki
第15行: | 第15行: | ||
输出: 8 | 输出: 8 | ||
</pre> | </pre> | ||
− | + | == 异或操作 == | |
+ | <source lang="java"> | ||
+ | class Solution { | ||
+ | public int missingNumber(int[] nums) { | ||
+ | int res = 0, i; | ||
+ | for (i = 0; i < nums.length; i++) { | ||
+ | res = res ^ i ^ nums[i]; | ||
+ | } | ||
+ | return res ^ i; | ||
+ | } | ||
+ | } | ||
+ | </source> | ||
[[category: 算法]] | [[category: 算法]] | ||
[[category: leetcode]] | [[category: leetcode]] | ||
[[category: 数学]] | [[category: 数学]] |
2018年6月4日 (一) 04:58的版本
描述
leetcode
https://leetcode-cn.com/problems/missing-number/description/
问题
给定一个包含 0, 1, 2, ..., n 中 n 个数的序列,找出 0 .. n 中没有出现在序列中的那个数。 示例 1: 输入: [3,0,1] 输出: 2 示例 2: 输入: [9,6,4,2,3,5,7,0,1] 输出: 8
异或操作
class Solution {
public int missingNumber(int[] nums) {
int res = 0, i;
for (i = 0; i < nums.length; i++) {
res = res ^ i ^ nums[i];
}
return res ^ i;
}
}