问题描述

一个整型数组 nums 里除两个数字之外,其他数字都出现了两次。请写程序找出这两个只出现一次的数字。要求时间复杂度是O(n),空间复杂度是O(1)。
示例 1: 输入:nums = [4,1,4,6]
输出:[1,6] 或 [6,1]
示例 2: 输入:nums = [1,2,10,4,1,4,3,3]
输出:[2,10] 或 [10,2]
  限制: 2 <= nums <= 10000

代码

首先给一个时间复杂度\(O(N)\)空间复杂度\(O(N)\)的算法:

class Solution {
public:
vector<int> singleNumbers(vector<int>& nums) {
map<int,int> table;
vector<int> ans;
for(int& num:nums)
{
++table[num];
}
for(auto &num:table)
{
if(num.second == 1)ans.push_back(num.first);
}
return ans;
}
};

结果

执行用时 :164 ms, 在所有 C++ 提交中击败了5.22%的用户
内存消耗 :20.4 MB, 在所有 C++ 提交中击败了100.00%的用户

代码

再给一个时间复杂度\(O(N\log(N))\)空间复杂度\(O(1)\)的算法:

class Solution {
public:
vector<int> singleNumbers(vector<int>& nums) {
int i,n =nums.size();
if(n == 2)return nums;
vector<int> ans;
sort(nums.begin(),nums.end());
if(nums[0]!=nums[1])ans.push_back(nums[0]);
if(nums[n-1]!=nums[n-2])ans.push_back(nums[n-1]);
for(i = 1; i < n-1; ++i)
{
if(nums[i] != nums[i-1] && nums[i]!= nums[i+1])
ans.push_back(nums[i]);
}
return ans;
}
};

结果

执行用时 :76 ms, 在所有 C++ 提交中击败了14.53%的用户
内存消耗 :16.5 MB, 在所有 C++ 提交中击败了100.00%的用户

代码

最后给一个时间复杂度\(O(N)\)空间复杂度\(O(1)\)的算法:

class Solution {
public:
vector<int> singleNumbers(vector<int>& nums) {
int i,n =nums.size(),x = 0;
if(n == 2)return nums;
vector<int> ans(2,0);
//将其全部 '异或' 起来,我们知道相同的两个数 '异或' 的话为0,那么两个1都抵消了,就剩1和6 '异或' 起来
for(int &num:nums)
x ^= num;
//我们用 x &= -x 来取出最右端为 ‘1’ 的位,
x &= -x;
//目标数必然分散在两个数组中,而且相同的数必然落在同一个数组中,相当于求解两个从只有一个元素只出现一次,其余元素都出现两次的数组中找出这一个元素的问题
for(int &num:nums)
{
if(x & num)ans[0] ^= num;
else ans[1] ^= num;
}
return ans;
}
};

结果

执行用时 :36 ms, 在所有 C++ 提交中击败了64.01%的用户
内存消耗 :16.2 MB, 在所有 C++ 提交中击败了100.00%的用户

《剑指offer》面试题56 - I. 数组中数字出现的次数的更多相关文章

  1. Leetcode - 剑指offer 面试题29:数组中出现次数超过一半的数字及其变形(腾讯2015秋招 编程题4)

    剑指offer 面试题29:数组中出现次数超过一半的数字 提交网址: http://www.nowcoder.com/practice/e8a1b01a2df14cb2b228b30ee6a92163 ...

  2. 面试题56 - I. 数组中数字出现的次数

    面试题56 - I. 数组中数字出现的次数 一个整型数组 nums 里除两个数字之外,其他数字都出现了两次.请写程序找出这两个只出现一次的数字.要求时间复杂度是O(n),空间复杂度是O(1). 示例 ...

  3. LeetCode 面试题56 - I. 数组中数字出现的次数 | Python

    面试题56 - I. 数组中数字出现的次数 题目 一个整型数组 nums 里除两个数字之外,其他数字都出现了两次.请写程序找出这两个只出现一次的数字.要求时间复杂度是O(n),空间复杂度是O(1). ...

  4. 力扣Leetcode 面试题56 - I. 数组中数字出现的次数

    面试题56 - I. 数组中数字出现的次数 一个整型数组 nums 里除两个数字之外,其他数字都出现了两次.请写程序找出这两个只出现一次的数字.要求时间复杂度是O(n),空间复杂度是O(1). 示例 ...

  5. (python)剑指Offer 面试题51:数组中重复的数字

    问题描述 在长度为n的数组中,所有的元素都是0到n-1的范围内. 数组中的某些数字是重复的,但不知道有几个重复的数字,也不知道重复了几次,请找出任意重复的数字. 例如,输入长度为7的数组{2,3,1, ...

  6. 剑指offer 面试题3:数组中重复的数字

    题目描述 在一个长度为n的数组里的所有数字都在0到n-1的范围内. 数组中某些数字是重复的,但不知道有几个数字是重复的.也不知道每个数字重复几次.请找出数组中任意一个重复的数字. 例如,如果输入长度为 ...

  7. 《剑指offer》面试题56 - II. 数组中数字出现的次数 II

    问题描述 在一个数组 nums 中除一个数字只出现一次之外,其他数字都出现了三次.请找出那个只出现一次的数字. 示例 1: 输入:nums = [3,4,3,3] 输出:4 示例 2: 输入:nums ...

  8. 剑指Offer面试题 二维数组中的查找

    题目链接:https://www.nowcoder.com/questionTerminal/abc3fe2ce8e146608e868a70efebf62e 题目大意: 略 分析: 对萌醒很开拓思维 ...

  9. 剑指 Offer 56 - II. 数组中数字出现的次数 II + 位运算

    剑指 Offer 56 - II. 数组中数字出现的次数 II Offer_56_2 题目详情 解题思路 java代码 package com.walegarrett.offer; /** * @Au ...

随机推荐

  1. 判断是否为空….IsEmpty(Power Query 之 M 语言)

    公式: 判断表:=Table.IsEmpty( 表) 判断列表:=List.IsEmpty( 列表) 说明: 此公式的参数一般是一个由公式生成的结果 最终效果: 表/列表中全部是空的返回true 表/ ...

  2. C语言程序设计:综合设计实验一(设计一个文字游戏)

    目录 C语言程序设计:综合设计实验一(设计一个文字游戏) 1.实验要求 2.设计思路 3.源码 4.后话 C语言程序设计:综合设计实验一(设计一个文字游戏) 1.实验要求 (1) 设计一个文字游戏,通 ...

  3. Python3.6+Django2.0以上 xadmin站点的配置和使用

    1. xadmin的介绍 django自带的admin站点虽然功能强大,但是界面不是很好看.而xadmin界面好看,功能更强大,并完全支持Bootstrap主题模板.xadmin内置了丰富的插件功能. ...

  4. Excel数据导出功能

    HTML代码: <a id="aExportData" hidden><span>Export</span></a> <div ...

  5. 分享自己做的一个指定进程以及线程长时间cpu监控的工具

    前言: 前面给大家分享过一个工作中用到的编译拷贝脚本,其实工作中还有一些其他工具的使用,今天再来分享一个自己纯手工的CPU监控的脚本.大家可以结合上篇文章与本篇文章一起学习shell. 主要实现功能: ...

  6. iframe父子页面js之间的调用

    父级页面:mian.html 子页面1:top.html 子页面2:index.html 页面关系 <div onclick="_top()">调用contentTop ...

  7. js中字符串和数组的常用转换处理方法

    1.split("分割条件(正则表达式或者字符)") 字符串 ==> 数组 默认返回数组 (1) 将单词分割为字符 "hello".split(" ...

  8. qt5之设置无边窗口移动

    Note qt version: 5.12 qt creator: 4.13 本文将介绍 设置无边窗口和设置窗口的移动 你要知道: QDialog 和 QMainWindow都是 QWidget的派生 ...

  9. 自定义C语言CVector

    CVector.h // // cvector.h // GKApp // // Created by 王明辉 on 16/4/15. // Copyright (c) 2016年 GK. All r ...

  10. 【LeetCode】35. Search Insert Position 解题报告(Java & Python)

    作者: 负雪明烛 id: fuxuemingzhu 个人博客: http://fuxuemingzhu.cn/ 目录 题目描述 题目大意 解题方法 二分查找 日期 题目地址:https://leetc ...