【剑指offer】面试题56 - II:数组中数字出现的次数 II(Java)

在一个数组 nums 中除一个数字只出现一次之外,其他数字都出现了三次。请找出那个只出现一次的数字。

示例 1:

输入:nums = [3,4,3,3]
输出:4
示例 2:

输入:nums = [9,1,7,9,7,9,7]
输出:1
 

限制:

1 <= nums.length <= 10000
1 <= nums[i] < 2^31
 

代码:

class Solution {

    public int singleNumber(int[] nums) {

        int result = 0;

        for(int i=0;i<32;i++)

        {

            int count = 0;

            for(int j =0;j<nums.length;j++)

            {

                if(((nums[j]>>i)&1)==1)

                {

                    count++;

                }

            }

            if(count%3!=0)

                {

                    result = result |(1<<i);

                }

        }

        return result;

    }

}

发布了275 篇原创文章 · 获赞 9 · 访问量 1万+

猜你喜欢

转载自blog.csdn.net/hx1043116928/article/details/104547457