(C++)只出现一次的数字III--异或
2023-12-15 13:14:23
?个人主页:Lei宝啊?
愿所有美好如期而遇
本题我们使用异或,先用0异或整个数组,结果就是两个只出现一次的整数的异或,之后我们再遍历数组,并且每次下标加二,如果相邻数据不同,我们取本下标的数据,然后用他去异或我们之前的异或,最后我们插入并返回这两个数。
class Solution {
public:
vector<int> singleNumber(vector<int>& nums)
{
sort(nums.begin(),nums.end());
vector<int> v;
int num = 0;
for(int i=0; i<nums.size(); i++)
{
num ^= nums[i];
}
for(int i=0; i<nums.size();)
{
if(nums[i] != nums[i+1])
{
v.push_back(nums[i]);
v.push_back(num^nums[i]);
return v;
}
else
{
i += 2;
}
}
return v;
}
};
文章来源:https://blog.csdn.net/m0_74824254/article/details/134907786
本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。 如若内容造成侵权/违法违规/事实不符,请联系我的编程经验分享网邮箱:veading@qq.com进行投诉反馈,一经查实,立即删除!
本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。 如若内容造成侵权/违法违规/事实不符,请联系我的编程经验分享网邮箱:veading@qq.com进行投诉反馈,一经查实,立即删除!