136 Single Number
2016-09-08 20:21
225 查看
问题描述:
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?
问题说明:题目要求时间复杂度O(n),不使用额外内存。只能再次借助位操作的特性。因为a^a=0,0^a = a.
也就是说,相同的两个数做异或可以抵消掉,0对任何数做异或不影响这个数。所以将所以的数在一起做一遍异或就可以了。
PS:对于异或的特性还需要多多了解,这方便欠缺很多
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?
问题说明:题目要求时间复杂度O(n),不使用额外内存。只能再次借助位操作的特性。因为a^a=0,0^a = a.
也就是说,相同的两个数做异或可以抵消掉,0对任何数做异或不影响这个数。所以将所以的数在一起做一遍异或就可以了。
PS:对于异或的特性还需要多多了解,这方便欠缺很多
int singleNumber(vector<int>& nums) { for(int i = 1; i<nums.size(); i++) { nums[0] ^= nums[i]; } return nums[0]; }
相关文章推荐
- 使用C++实现JNI接口需要注意的事项
- 关于指针的一些事情
- c++ primer 第五版 笔记前言
- share_ptr的几个注意点
- Lua中调用C++函数示例
- Lua教程(一):在C++中嵌入Lua脚本
- Lua教程(二):C++和Lua相互传递数据示例
- 使用位运算实现网页中的过滤、筛选功能实例
- C++联合体转换成C#结构的实现方法
- C++高级程序员成长之路
- C++编写简单的打靶游戏
- C++ 自定义控件的移植问题
- C++变位词问题分析
- C/C++数据对齐详细解析
- C++基于栈实现铁轨问题
- C++中引用的使用总结
- 使用Lua来扩展C++程序的方法
- C++中调用Lua函数实例
- Lua和C++的通信流程代码实例
- C++的template模板中class与typename关键字的区别分析