LeetCode: Single Number I && II
I title:
Given an array of integers, every element appears twice except for one. Find that single one.
Note:
Your algorithm should have a linear runtime complexity. Could you implement it without using extra memory?
思路:异或
class Solution {
public:
    int singleNumber(vector<int>& nums) {
        int single = nums[];
        for (int i =  ;i < nums.size(); i++){
            single ^= nums[i];
        }
        return single;
    }
};
II
title:
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?
思路:
这里我们需要重新思考,计算机是怎么存储数字的。考虑全部用二进制表示,如果我们把 第 ith 个位置上所有数字的和对3取余,那么只会有两个结果 0 或 1 (根据题意,3个0或3个1相加余数都为0). 因此取余的结果就是那个 “Single Number”.
一个直接的实现就是用大小为 32的数组来记录所有 位上的和。
class Solution {
public:
    int singleNumber(vector<int>& nums) {
        vector<int> v(,);
        int result = ;
        for (int i = ; i < ; i++){
            for (int j =  ;j < nums.size(); j++){
                if ((nums[j] >> i) & )
                    v[i]++;
            }
            result |= ((v[i] % ) << i);
        }
        return result;
    }
};
这个算法是有改进的空间的,可以使用掩码变量:
- ones代表第ith 位只出现一次的掩码变量
- twos代表第ith 位只出现两次次的掩码变量
- threes代表第ith 位只出现三次的掩码变量
假设在数组的开头连续出现3次5,则变化如下:
ones =
twos =
threes =
--------------
ones =
twos =
threes =
--------------
ones =
twos =
threes =
--------------
当第 ith 位出现3次时,我们就 ones  和 twos  的第 ith 位设置为0. 最终的答案就是 ones。
class Solution {
public:
    int singleNumber(vector<int>& nums) {
        int one = , two = , three = ;
        for (int i = ; i < nums.size(); i++){
            two |= (one & nums[i]);
            one ^= nums[i];
            three = one & two;
            one &= ~three;
            two &= ~three;
        }
        return one;
    }
};
LeetCode: Single Number I && II的更多相关文章
- LeetCode Single Number I / II / III
		[1]LeetCode 136 Single Number 题意:奇数个数,其中除了一个数只出现一次外,其他数都是成对出现,比如1,2,2,3,3...,求出该单个数. 解法:容易想到异或的性质,两个 ... 
- LeetCode Single Number I II Python
		Single Number Given an array of integers, every element appears twice except for one. Find that sing ... 
- 4.Single Number  && Single Number (II)
		Single Number: 1. Given an array of integers, every element appears twice except for one. Find that ... 
- [LeetCode] Single Number II 单独的数字之二
		Given an array of integers, every element appears three times except for one. Find that single one. ... 
- LeetCode——Single Number II(找出数组中只出现一次的数2)
		问题: Given an array of integers, every element appears three times except for one. Find that single o ... 
- 【LeetCode】Single Number I & II & III
		Single Number I : Given an array of integers, every element appears twice except for one. Find that ... 
- LeetCode 【Single Number I II III】
		Given an array of integers, every element appears twice except for one. Find that single one. 思路: 最经 ... 
- Leetcode 137. Single Number I/II/III
		Given an array of integers, every element appears twice except for one. Find that single one. 本题利用XO ... 
- LeetCode:Single Number II
		题目地址:here 题目大意:一个整数数组中,只有一个数出现一次,其余数都出现3次,在O(n)时间,O(1)空间内找到这个出现一次的数 对于”只有一个数出现一次,其余数出现2次“的情况,很简单,只要把 ... 
随机推荐
- [转载]C# 多线程、控制线程数提高循环输出效率
			C#多线程及控制线程数量,对for循环输出效率. 虽然输出不规律,但是效率明显提高. 思路: 如果要删除1000条数据,只使用for循环,则一个接着一个输出.所以,把1000条数据分成seed段,每段 ... 
- Windows ftp 连不上Linux
			1.首先检查vsftpd服务器 是否安装 $ rpm -qa | grep vsftpdvsftpd-2.2.2-11.el6.x86_64 2.显示已安装,restart the vsftpd ¥ ... 
- Openstack Grizzily 单节点测试机安装( All In One CentOS/RHEL)
			Openstack Grizzily版本已经相当完善,根据官方文档安装基本不存在什么问题,但是想快速测试了解Openstack功能的用户非常多,devstack的安 装需要check最新的代码,时常碰 ... 
- 2016,除了 DevOps,企业还应该知道 CMDB!
			CMDB 是 Configuration Management Database(配置管理数据库)的简称,CMDB 存储与管理企业 IT 架构中设备的各种配置信息,它与所有服务支持和服务交付流程都紧密 ... 
- POJ 3280 Cheapest Palindrome(DP)
			题目链接 题意 :给你一个字符串,让你删除或添加某些字母让这个字符串变成回文串,删除或添加某个字母要付出相应的代价,问你变成回文所需要的最小的代价是多少. 思路 :DP[i][j]代表的是 i 到 j ... 
- 套题T8&T9
			A - 8球胜负(eight) Time Limit:1000MS Memory Limit:65535KB 64bit IO Format:%lld & %llu Submi ... 
- lintcode:anagrams  乱序字符串
			题目 乱序字符串 给出一个字符串数组S,找到其中所有的乱序字符串(Anagram).如果一个字符串是乱序字符串,那么他存在一个字母集合相同,但顺序不同的字符串也在S中. 您在真实的面试中是否遇到过这个 ... 
- [topcoder]HappyLetterDiv2
			http://community.topcoder.com/stat?c=problem_statement&pm=13245 就是有字符串,里面的字符可以随意两两消除,如果不等的话,那么最后 ... 
- utf-8中的汉字占用多少字节
			转载:http://blog.csdn.net/chummyhe89/article/details/7777613 占2个字节的:〇 占3个字节的:基本等同于GBK,含21000多个汉字 占4个字节 ... 
- iOS开发--使用NSMutableAttributedString 实现富文本
			在iOS开发中,常常会有一段文字显示不同的颜色和字体,或者给某几个文字加删除线或下划线的需求.之前在网上找了一些资料,有的是重绘UILabel的textLayer,有的是用html5实现的,都比较麻烦 ... 
