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

本文共 1896 字,大约阅读时间需要 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<int>& 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<int>& nums){               unordered_map <int, int> 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<Key,T>::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<const Key,T>) 

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

你可能感兴趣的文章
最简单的Socket程序[入门篇]
查看>>
VS2005图标默认存放位置
查看>>
常用正则表达式
查看>>
C#中换行的代码
查看>>
用正则表达式过滤多余空格
查看>>
XML:采用XHTML和CSS设计可重用可换肤的WEB站点
查看>>
less简介、less安装、编译、less语法之变量、嵌套、类混入、函数混入、运算、less文件导入
查看>>
【springmvc】传值的几种方式&&postman接口测试
查看>>
泳道图简介
查看>>
Tomcat6中web项目部署路径webapps和wtpwebapps的区别
查看>>
Java判断字符串是否为金额
查看>>
CodeCombat代码全记录(Python学习利器)--安息之云山峰(第四章)代码9
查看>>
skyfans之每天一个Liunx命令系列之二:uptime
查看>>
Kubernetes十三--Pod定义文件内容详解
查看>>
3、69道Spring面试题及答案
查看>>
普歌- LRF-(简单易懂)笔记本电脑USB接口案例 接口多态(向下转型)
查看>>
Java中如何构建树结构
查看>>
解决vue部署到nginx后刷新404
查看>>
解决eclipse字体背景变红或者变绿的问题
查看>>
扫雷小游戏——简单易懂
查看>>