当前位置:网站首页>剑指 Offer 56 - I. 数组中数字出现的次数
剑指 Offer 56 - I. 数组中数字出现的次数
2022-08-09 03:15:00 【田园诗人之园】
一个整型数组 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.length <= 10000
来源:力扣(LeetCode)
链接:https://leetcode-cn.com/problems/shu-zu-zhong-shu-zi-chu-xian-de-ci-shu-lcof
著作权归领扣网络所有。商业转载请联系官方授权,非商业转载请注明出处。
首先将数组排序,然后依次从前往后遍历,如果前后两个元素相等,则向后偏移两个位置,否则记录当前元素,向后偏移一个位置。该方法由于使用sort()的缘故,会使得算法的时间复杂度变为O(NlogN)
class Solution {
public:
vector<int> singleNumbers(vector<int>& nums) {
vector<int> res;
int n = nums.size();
int i = 0;
sort(nums.begin(), nums.end());
for (i = 0; i < n - 1;) {
if (nums[i] == nums[i + 1]) {
i += 2;
continue;
}
res.push_back(nums[i]);
i++;
}
if (i == n - 1) {
res.push_back(nums[i]);
}
return res;
}
};
采用官网上给出的方法:
class Solution {
public:
vector<int> singleNumbers(vector<int>& nums) {
vector<int> res;
int ans = 0;
int a = 0, b = 0;
for (auto &i: nums) {
ans ^= i;
}
int div = 1;
while ((div & ans) == 0) {
div <<= 1;
}
for (auto &i: nums) {
if (div & i) {
a ^= i;
}
else {
b ^= i;
}
}
res.push_back(a);
res.push_back(b);
return res;
}
};
边栏推荐
猜你喜欢
2021-07-21
365 days challenge LeetCode1000 topic - Day 051 special binary sequence partition
甲乙丙丁加工零件,加工的总数是370, 如果甲加工的零件数多10,如果乙加工的零件数少20,如果丙加工的 零件数乘以2,如果丁加工的零件数除以2,四个人的加工数量相等,求甲乙丙丁各自加工多少个零件?
卷积神经网络的推导过程
嵌入式系统驱动高级【2】——平台总线式驱动开发上_基础框架
【扫雷--2】
i18n 国际化
Leetcode刷题——148. 排序链表
Introduction to the JSP
C专家编程 第9章 再论数组 9.3 为什么C语言把数组形参当做指针
随机推荐
2022-08-08 第五小组 顾祥全 学习笔记 day31-集合-IO流-File类
光刻机随感
手把手教你uniapp接入聊天IM即时通讯功能-源码分享
别了,IE浏览器
高并发+海量数据下如何实现系统解耦?【中】
JSON beautification plugin for Chrome
Arrays and slices
Win7电脑无法进入睡眠模式?
Hcip MPLS experiment
以赛促练-力扣第84场双周赛反思以及第305场周赛补题
2022-08-08 The fifth group Gu Xiangquan study notes day31-collection-IO stream-File class
C专家编程 第8章 为什么程序员无法分清万圣节和圣诞节 8.10 轻松一下---国际C语言混乱代码大赛
cmd路径空格问题解决方案
DSPE-PEG-OH,DSPE-PEG-Hydroxyl,磷脂-聚乙二醇-羟基仅供科研实验使用
01| Data Type
Zabbix 5.0 监控教程(五)
那些关于DOM的常见Hook封装(一)
MySQL相关知识 和 数据的存储相关知识
佛性问题排查小结
数据库工具DataGrip V2022.2正式发布——支持导入多个 CSV 文件的选项