题目
一个整型数组里除了两个数字之外,其他的数字都出现了两次。请写程序找出这两个只出现一次的数字。
1、我看大佬们都是用二进制的运算来做的,本人计算机渣渣,对这些按位运算看的头晕,这里提供一个不同的解题思路。
2、利用set的不可重复性,遍历数组放入set,如果放入失败,说明里面原来已经有了同样的数,就把原来的数删除,最后剩下的就是那两个只出现一次的数。
3、这里说明一点Integer[] res = set.toArray(new Integer[0]);,这一句中的new Integer[0],是要指定set转化为数组后的类型。因为set只知道自己装的是Object类型的,所以如果不加这个的话,必须用Object类型来接收。
//num1,num2分别为长度为1的数组。传出参数
//将num1[0],num2[0]设置为返回结果
import java.util.Set;
import java.util.HashSet;
public class Solution {
public void FindNumsAppearOnce(int [] array,int num1[] , int num2[]) {
Set<Integer> set = new HashSet<>();
for(int i = 0; i < array.length; i ++){
if(!set.add(array[i])){
set.remove(array[i]);
}
}
Integer[] res = set.toArray(new Integer[0]);
num1[0] = res[0];
num2[0] = res[1];
}
}
寻找唯一数字的创新算法

本文介绍了一种新颖的方法来解决寻找整型数组中仅出现一次的两个数字的问题。通过利用set的特性,该方法避免了复杂的二进制运算,提供了一个简洁且直观的解决方案。
2184

被折叠的 条评论
为什么被折叠?



