哈希、位运算-数组中只出现一次的数字

数组中只出现一次的数字

http://www.nowcoder.com/questionTerminal/e02fdb54d7524710a7d664d082bb7811

题目描述
一个整型数组里除了两个数字之外,其他的数字都出现了两次。请写程序找出这两个只出现一次的数字。
两个解法:哈希和位运算
解法一思路:哈希 10ms 9892KB
用HashMap记录每个数字出现的次数,最后遍历出现一次的数字

import java.util.*;
public class Solution {
    public void FindNumsAppearOnce(int [] array,int num1[] , int num2[]) {
        HashMap<Integer,Integer> ans=new HashMap<>();
        for(int i=0;i<array.length;i++){
            if(ans.containsKey(array[i])){
                ans.put(array[i],2);
            }
            else{
                ans.put(array[i],1);
            }
        }
        boolean flag=true;
        for(Integer key:ans.keySet()){
            if(ans.get(key)==1){
                if(flag){
                    flag=false;
                    num1[0]=key;
                }
                else{
                    num2[0]=key;
                }
            }
        }
    }
}

解法二思路:位运算 10ms 9808KB

1、异或思想,一个数与自己异或为0,一个数与0异或为自己

2、由于其它数字两两相同,所以所有数异或则得到这两个不同数的异或结果。取这个结果的第一个1作为标志位

3、这个标志的1,必须是:这两个数在该位一个为0,一个为1

4、这样可以将数组分为两组,一组在该标志位为1,一组在该标志位为0,这两个不同数字分别在这两组内

5、将两组内的数分别异或,得到两个结果则为这两个不同的数

//num1,num2分别为长度为1的数组。传出参数
//将num1[0],num2[0]设置为返回结果
import java.util.*;
public class Solution {
    public void FindNumsAppearOnce(int [] array,int num1[] , int num2[]) {
        if(array.length<2) return;
        //求数组中所有元素的异或值
        int num=0;
        for(int i=0;i<array.length;i++){
            num=num^array[i];
        }
        //找num中最右侧1出现的位置index
        int count=1;
        while((num & count)==0){
            count=count<<1;//从最低位为1,依次将1左移
        }
        //count为只有index位为1的数
        num1[0]=0;
        num2[0]=0;
        for(int i=0;i<array.length;i++){
            if((array[i] & count)==0){//index为0的所有数
                num1[0]=num1[0]^array[i];
            }
            else{
                num2[0]=num2[0]^array[i];
            }
        }
    }
}
全部评论

相关推荐

02-01 12:05
复旦大学 Java
腾讯的提前批大概率应该是没有笔试的,但是这个时候有相当部分的同学简历估计都没有准备好,没准备好的同学也不用急,大部分都是3月之后开,这个时候开的绝大多数都是神仙打架,问的东西也比较难,打算投递的同学也多看下计算机网络和操作系统,腾讯对这部分的知识问的比较多。另外多刷下牛客的热门题库,刷题注意刷ACM模式,和牛客的周赛题,腾讯有的部门会从这里面出原题。我是@程序员花海关注我,带你了解更多校招资讯!
程序员花海:还没有来得及准备的同学可以看下学习路线:https://www.nowcoder.com/discuss/824693499982315520?sourceSSR=users算法题:https://www.nowcoder.com/feed/main/detail/20e7a999fa04485b88340a274411ca0d?sourceSSR=users八股文:https://www.nowcoder.com/discuss/833102362771251200?sourceSSR=users简历书写方式:https://www.nowcoder.com/discuss/839907820706205696?sourceSSR=users都是以前在牛客发的文章~
软开人,秋招你打算投哪些...
点赞 评论 收藏
分享
评论
点赞
收藏
分享

创作者周榜

更多
牛客网
牛客网在线编程
牛客网题解
牛客企业服务