其他分享
首页 > 其他分享> > 82. 落单的数 ( 位运算-统计 )

82. 落单的数 ( 位运算-统计 )

作者:互联网

LintCode: 82. 落单的数

在这里插入图片描述


老问题了。

解决一个数出现一次,其他出现 n 次的 模板


AC Code

public class Solution {
    /**
     * @param A: An integer array
     * @return: An integer
     */
    public int singleNumber(int[] a) {
        // write your code here
        int len = a.length;
        int ans = 0;
        int[] count = new int[32];
        
        for(int i = 0; i < len; i++){
            for(int j = 0; j < 32; j++){
                count[j] += a[i] & 1;
                // 右移
                a[i] = a[i] >>> 1;
            }
        }
        
        // 计算结果
        // k 其他出现了 2 次
        int k = 2;
        
        for(int i = 31; i >= 0; i--){
            ans <<= 1;
            ans |= count[i] % k ;
        }
        return ans;
    }
}



标签:落单,运算,int,len,ans,82,public
来源: https://blog.csdn.net/qq_43765535/article/details/111059191