LeetCode137—Single Number II
来源:互联网 发布:php header 404 无效 编辑:程序博客网 时间:2024/05/21 00:54
原题
原题链接
Given an array of integers, every element appears three times except for one. Find that single one.
分析
改进了一下,在出现所有元素都三次的序列中找出只出现一次的元素。
用Hash是能Accept的,但是题目说了,线性时间和不用额外空间的要求,还是用逻辑运算来做。
我想到了不用额外空间的方法,但是线性时间还是达不到要求:
1.先排序
2.排序后每3个数往后迭代
3.三个数前两数异或不为0则返回第一个数。
代码
1.hash的版本
class Solution {public: int singleNumber(vector<int>& nums) { unordered_map<int,int>table; for(int i=0;i<nums.size();i++) { table[nums[i]]=table[nums[i]]+1; } for(auto it = table.begin();it!=table.end();it++) { if(it->second==1) return it->first; else continue; } return nums[0]; }};
2.异或的版本
class Solution {public: int singleNumber(vector<int>& nums) { if(nums.size()==1) return nums[0]; sort(nums.begin(),nums.end()); for(int i=0;i<nums.size()-2;i+=3) { int n1=nums[i]; int n2=nums[i+1]; int flag1=n1^n2; if(flag1!=0) return n1; } return nums[nums.size()-1]; }};
1 0
- LeetCode137—Single Number II
- leetcode137 Single Number II
- LeetCode137 Single Number II
- leetcode137. Single Number II
- leetcode137~Single Number II
- LeetCode137. Single Number II
- LeetCode137——Single Number II
- leetcode137 Single Number II java
- **LeetCode137. Single Number II_M
- Single Number & Single Number II
- Single Number & Single Number II
- LeetCode——136. Single Number&&137. Single Number II
- LeetCode OJ——Single Number II
- LeetCode——Single Number(II)
- LeetCode——Single Number II
- leetcode 137 —— Single Number II
- LeetCode——Single Number II
- LeetCode — Single Number II 解题报告
- 第2周项目2-程序的多文件组织
- 【R语言数据处理】一步一步来分析数据之不知哪位收集的淘宝推荐的数据之二,数据分析(1)直方图,饼图
- 题目1:添加赋值运算符函数
- spring中非注解类调用注解类
- 第2周项目1-C/C++语言中函数参数传递的三种方式
- LeetCode137—Single Number II
- 第一周项目0-宣告“主权”
- NYOJ1129-很新颖的DFS
- Target runtime Apache Tomcat v6.0 is not defined
- 第二周项目0 宣告“主权”
- 项目0-宣告“主权”
- Web漏洞
- Linux下的mono开发环境搭建(日志)
- iOS APP发布流程