auto commit

This commit is contained in:
CyC2018 2020-11-05 01:01:54 +08:00
parent 2e03e23206
commit efab8d1fcf
2 changed files with 18 additions and 6 deletions

View File

@ -1,6 +1,8 @@
# 56. 数组中只出现一次的数字
[NowCoder](https://www.nowcoder.com/practice/e02fdb54d7524710a7d664d082bb7811?tpId=13&tqId=11193&tPage=1&rp=1&ru=/ta/coding-interviews&qru=/ta/coding-interviews/question-ranking&from=cyc_github)
## 题目链接
[牛客网](https://www.nowcoder.com/practice/e02fdb54d7524710a7d664d082bb7811?tpId=13&tqId=11193&tPage=1&rp=1&ru=/ta/coding-interviews&qru=/ta/coding-interviews/question-ranking&from=cyc_github)
## 题目描述
@ -8,9 +10,13 @@
## 解题思路
两个不相等的元素在位级表示上必定会有一位存在不同将数组的所有元素异或得到的结果为不存在重复的两个元素异或的结果
两个相等的元素异或的结果为 0 0 与任意数 x 异或的结果都为 x
diff &= -diff 得到出 diff 最右侧不为 0 的位也就是不存在重复的两个元素在位级表示上最右侧不同的那一位利用这一位就可以将两个元素区分开来
对本题给的数组的所有元素执行异或操作得到的是两个不存在重复的元素异或的结果例如对于数组 [x,x,y,y,z,k]x^x^y^y^z^k = 0^y^y^z^k = y^y^z^k = 0^z^k = z^k
两个不相等的元素在位级表示上一定会有所不同因此这两个元素异或得到的结果 diff 一定不为 0位运算 diff & -diff 能得到 diff 位级表示中最右侧为 1 的位 diff = diff & -diff diff 作为区分两个元素的依据一定有一个元素对 diff 进行异或的结果为 0另一个结果非 0设不相等的两个元素分别为 z k遍历数组所有元素判断元素与 diff 的异或结果是否为 0如果是的话将元素与 z 进行异或并赋值给 z否则与 k 进行异或并赋值给 k数组中相等的元素一定会同时与 z 或者与 k 进行异或操作而不是一个与 z 进行异或一个与 k 进行异或而且这些相等的元素异或的结果为 0因此最后 z k 只是不相等的两个元素与 0 异或的结果也就是不相等两个元素本身
下面的解法中num1 num2 数组的第一个元素是用来保持返回值的... 实际开发中不推荐这种返回值的方式
```java
public void FindNumsAppearOnce(int[] nums, int num1[], int num2[]) {

View File

@ -1,6 +1,8 @@
# 56. 数组中只出现一次的数字
[NowCoder](https://www.nowcoder.com/practice/e02fdb54d7524710a7d664d082bb7811?tpId=13&tqId=11193&tPage=1&rp=1&ru=/ta/coding-interviews&qru=/ta/coding-interviews/question-ranking&from=cyc_github)
## 题目链接
[牛客网](https://www.nowcoder.com/practice/e02fdb54d7524710a7d664d082bb7811?tpId=13&tqId=11193&tPage=1&rp=1&ru=/ta/coding-interviews&qru=/ta/coding-interviews/question-ranking&from=cyc_github)
## 题目描述
@ -8,9 +10,13 @@
## 解题思路
两个不相等的元素在位级表示上必定会有一位存在不同将数组的所有元素异或得到的结果为不存在重复的两个元素异或的结果
两个相等的元素异或的结果为 0 0 与任意数 x 异或的结果都为 x
diff &= -diff 得到出 diff 最右侧不为 0 的位也就是不存在重复的两个元素在位级表示上最右侧不同的那一位利用这一位就可以将两个元素区分开来
对本题给的数组的所有元素执行异或操作得到的是两个不存在重复的元素异或的结果例如对于数组 [x,x,y,y,z,k]x^x^y^y^z^k = 0^y^y^z^k = y^y^z^k = 0^z^k = z^k
两个不相等的元素在位级表示上一定会有所不同因此这两个元素异或得到的结果 diff 一定不为 0位运算 diff & -diff 能得到 diff 位级表示中最右侧为 1 的位 diff = diff & -diff diff 作为区分两个元素的依据一定有一个元素对 diff 进行异或的结果为 0另一个结果非 0设不相等的两个元素分别为 z k遍历数组所有元素判断元素与 diff 的异或结果是否为 0如果是的话将元素与 z 进行异或并赋值给 z否则与 k 进行异或并赋值给 k数组中相等的元素一定会同时与 z 或者与 k 进行异或操作而不是一个与 z 进行异或一个与 k 进行异或而且这些相等的元素异或的结果为 0因此最后 z k 只是不相等的两个元素与 0 异或的结果也就是不相等两个元素本身
下面的解法中num1 num2 数组的第一个元素是用来保持返回值的... 实际开发中不推荐这种返回值的方式
```java
public void FindNumsAppearOnce(int[] nums, int num1[], int num2[]) {