博客
关于我
[Easy] 136. Single Number
阅读量:356 次
发布时间:2019-03-04

本文共 1909 字,大约阅读时间需要 6 分钟。

136. Single Number

Given a non-empty 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?

Example 1:Input: [2,2,1]Output: 1Example 2:Input: [4,1,2,1,2]Output: 4

Solution

Bit Operation

Runtime: 24 ms, faster than 30.74% of C++ online submissions for Single Number.

Memory Usage: 12.1 MB, less than 6.17% of C++ online submissions for Single Number.
时间复杂度O(n),空间复杂度O(1)

class Solution {   public:    int singleNumber(vector
& nums) { int a = 0; for(int i = 0; i < nums.size(); i++) { a^=nums[i]; } return a; }};

这是个比较巧妙的方法,采用位运算——异或。根据异或的性质有:

a ⊕ a = 0 , a ⊕ 0 = a , a ⊕ a ⊕ b = b , ( a ⊕ b ) ⊕ ( a ⊕ b ) = ( a ⊕ a ) ⊕ ( b ⊕ b ) = 0 \\ a\oplus a=0, \\ a\oplus 0 = a, \\ a\oplus a\oplus b = b, \\ (a\oplus b) \oplus (a\oplus b) = (a\oplus a) \oplus (b\oplus b) = 0 aa=0,a0=a,aab=b,(ab)(ab)=(aa)(bb)=0
所以,可以总结为:如果相同则对应位为0, 如果不同则对应位为1。我们想要找到一个与众不同的元素,也就是需要每个元素间互相异或,这样所有相同的元素异或均为0,那么剩下的就是我们想要的答案了。

Hash Table

Runtime: 36 ms, faster than 16.05% of C++ online submissions for Single Number.

Memory Usage: 14 MB, less than 6.17% of C++ online submissions for Single Number.
时间复杂度O(n),空间复杂度O(n)

class Solution{       public:        int singleNumber(vector
& nums){ unordered_map
nums_map; for(int i = 0; i < nums.size(); i++) nums_map[nums[i]]++; for(auto it = nums_map.begin(); it != nums_map.end(); it++) if(it->second == 1) return it->first; return nums[0]; }};

it迭代器:

unordered_map
::iterator it;(*it).first; // the key value (of type Key)(*it).second; // the mapped value (of type T)(*it); // the "element value" (of type pair
)

转载地址:http://kbir.baihongyu.com/

你可能感兴趣的文章
MySQL中group by 与 order by 一起使用排序问题
查看>>
mysql中having的用法
查看>>
MySQL中interactive_timeout和wait_timeout的区别
查看>>
mysql中int、bigint、smallint 和 tinyint的区别、char和varchar的区别详细介绍
查看>>
mysql中json_extract的使用方法
查看>>
mysql中json_extract的使用方法
查看>>
mysql中kill掉所有锁表的进程
查看>>
mysql中like % %模糊查询
查看>>
MySql中mvcc学习记录
查看>>
mysql中null和空字符串的区别与问题!
查看>>
MySQL中ON DUPLICATE KEY UPDATE的介绍与使用、批量更新、存在即更新不存在则插入
查看>>
MYSQL中TINYINT的取值范围
查看>>
MySQL中UPDATE语句的神奇技巧,让你操作数据库如虎添翼!
查看>>
Mysql中varchar类型数字排序不对踩坑记录
查看>>
MySQL中一条SQL语句到底是如何执行的呢?
查看>>
MySQL中你必须知道的10件事,1.5万字!
查看>>
MySQL中使用IN()查询到底走不走索引?
查看>>
Mysql中使用存储过程插入decimal和时间数据递增的模拟数据
查看>>
MySql中关于geometry类型的数据_空的时候如何插入处理_需用null_空字符串插入会报错_Cannot get geometry object from dat---MySql工作笔记003
查看>>
mysql中出现Incorrect DECIMAL value: '0' for column '' at row -1错误解决方案
查看>>