[leetcode] 【数组】 137. Single Number II

原创 2016年05月30日 10:32:18

Given an array of integers, every element appears three times except for one. Find that single one.

Note:

Your algorithm should have a linear runtime complexity. Could you implement it without using extra memory?


题意

一个整数数组中,有一个元素只出现一次,其他每个元素都出现3次,找出这个元素。

题解

这里也是根据位的特性来处理,用于一个int所占bit数大小的数组count来存储二进制数的每一位。
把nums数组所有数都按位加在count数组中,然后对3求余,剩下的数就是只出现一次的数。

class Solution {
public:
    int singleNumber(vector<int>& nums) {
        const int sizeint=sizeof(int)*8;
        vector<int> count(sizeint);
        for(auto i: nums)
        {
            for(int j=0;j<sizeint;j++)
            {
                count[j]+=(i>>j) &1;
                count[j]%=3;
            }
        }
        int res=0;
        for(int i=0;i<sizeint;i++)
            res+=(count[i]<<i);
        return res;
    }
};



版权声明:本文为博主原创文章,未经博主允许不得转载。

LeetCode 260 Single Number III(只出现一次的数字 III)(*)

原文给定一个数字数组nums,其中有两个元素只出现一次,而其他所有元素均出现两次。找出这两个只出现一次的元素。例如:给定nums = [1, 2, 1, 3, 2, 5],返回[3, 5]。备注: 1...
  • NoMasp
  • NoMasp
  • 2016年02月18日 15:06
  • 4424

【LeetCode-面试算法经典-Java实现】【137-Single Number II(只字出一次的数字II)】

【137-Single Number II(只出现一次的数字II)】【LeetCode-面试算法经典-Java实现】【所有题目目录索引】原题  Given an array of integers, ...
  • DERRANTCM
  • DERRANTCM
  • 2015年08月18日 06:24
  • 3908

Leetcode 240 Search a 2D Matrix II (二分法和分治法解决有序二维数组查找)

1.问题描述  写一个高效的算法,从一个m×nm\times n的整数矩阵中查找出给定的值,矩阵具有如下特点:    每一行从左到右递增。 每一列从上到下递增。 2. 方法与思路2.1 二分查找法 ...
  • Jeanphorn
  • Jeanphorn
  • 2015年07月23日 20:41
  • 3091

LeetCode(137) Single Number II

题目Given an array of integers, every element appears three times except for one. Find that single one...
  • fly_yr
  • fly_yr
  • 2015年10月22日 13:19
  • 327

【LeetCode】137. Single Number II

137. Single Number II Given an array of integers, every element appears three times except for one...
  • winghare
  • winghare
  • 2016年01月23日 14:18
  • 172

Leetcode 137. Single Number II

题意:给定一个数组,已知这个数组中有一个数出现了一次,其它数都出现三次。找出这个数 解法: 有个很好理解的解法,因为int有32位,所以开一个数组bit[32],遍历32次,把每个位出现的次数分别...
  • ujn11456963
  • ujn11456963
  • 2016年09月17日 15:44
  • 156

leetcode[137]:Single Number II

Single Number IIGiven an array of integers, every element appears three times except for one. Find t...
  • hahubaba
  • hahubaba
  • 2015年07月25日 14:27
  • 164

Leetcode 137 Single Number II 仅出现一次的数字

给出一个整数数组,除了某个元素外所有元素都出现三次。找出仅出现一次的数字。...
  • smile_watermelon
  • smile_watermelon
  • 2015年08月18日 10:34
  • 785

leetcode-137 Single Number II

思路一: 对于除出现一次之外的所有的整数,其二进制表示中每一位1出现的次数是3的整数倍,将所有这些1清零,剩下的就是最终的数。用ones记录到当前计算的变量为止,二进制1出现“1次”(mod 3...
  • sole_cc
  • sole_cc
  • 2015年03月03日 11:14
  • 412

<LeetCode OJ> 136 / 137 / 260 Single Number(I / II / III)

260. Single Number III My Submissions Question Total Accepted: 19802 Total Submissions: 47891 Di...
  • EbowTang
  • EbowTang
  • 2016年01月01日 16:11
  • 987
内容举报
返回顶部
收藏助手
不良信息举报
您举报文章:[leetcode] 【数组】 137. Single Number II
举报原因:
原因补充:

(最多只允许输入30个字)