程序员面试金典 - 面试题 17.19. 消失的两个数字(数学/位运算)

1. 题目

给定一个数组,包含从 1 到 N 所有的整数,但其中缺了两个数字。

你能在 O(N) 时间内只用 O(1) 的空间找到它们吗?

以任意顺序返回这两个数字均可。

示例 1:
输入: [1]
输出: [2,3]示例 2:
输入: [2,3]
输出: [1,4]提示:
nums.length <= 30000

来源:力扣(LeetCode)
链接:https://leetcode-cn.com/problems/missing-two-lcci
著作权归领扣网络所有。商业转载请联系官方授权,非商业转载请注明出处。

2. 解题

2.1 数学公式

12+22+32+42+....+n2=n∗(n+1)∗(2n+1)/61^2+2^2+3^2+4^2+....+n^2 = n*(n+1)*(2n+1)/612+22+32+42+....+n2=n(n+1)(2n+1)/6
1+2+...+n=n∗(1+n)/21+2+...+n = n*(1+n)/21+2+...+n=n(1+n)/2

class Solution {
public:vector<int> missingTwo(vector<int>& nums) {int n = nums.size()+2, a, b;long sum = 0, squareSum = 0;for(int i = 0; i < nums.size(); ++i){sum += nums[i];squareSum += nums[i]*nums[i];}squareSum = long(n)*(n+1)*(2*n+1)/6 - squareSum;sum = n*(n+1)/2 - sum;for(a = 1; a <= n; ++a){if(2*a*(sum-a) == sum*sum - squareSum)break;}b = sum-a;return {a,b};}
};

72 ms 22.5 MB

2.2 常规解法

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

116 ms 22.4 MB

2.3 位运算

  • 0 异或所有数,以及1-n的所有数,只出现1次的两个数的异或值得到了
  • 把上面异或值不为0的二进制位找到
  • 用这个位把 1到n 和数组里的数(2n-2 个),按照上面找出的二进制位,分成2组
  • 即得到出现1次的两个数
class Solution {
public:vector<int> missingTwo(vector<int>& nums) {int XOR = 0, a = 0, b = 0, i;for(auto& n : nums) XOR ^= n;for(i = 1; i <= nums.size()+2; ++i) XOR ^= i;for(i = 0; i < 32; ++i)if(XOR&(1<<i))//a、b二进制不同的位break;// i为 a,b 不相同的二进制位for(auto& n : nums){if((n>>i)&1)//分组a ^= n;elseb ^= n;}for(int j = 1; j <= nums.size()+2; ++j){if((j>>i)&1)a ^= j;elseb ^= j;}return {a,b};}
};

80 ms 22.3 MB

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/476851.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

其实没事做,写写博客也不错的

以前一直很喜欢记录自己的一些事情&#xff0c;现在有博客这个东西了&#xff0c;但是懒得很&#xff0c;申请N多没有一个坚持记录下去的&#xff0c;希望在博客园可以好好安家。。今晚竟然看博客看到11.00了&#xff0c;要洗澡睡觉了。。明天要搞定PES、还要开会。。。事情有点…

python sorted下标_Python列表操作最全面总结

1.列表添加元素列表中可以使用append、insert、extend方法实现元素的添加。append会把新元素添加到列表末尾"a", insert(index, object) 在指定位置index前插入元素object"a", 通过extend可以将另一个集合中的元素逐一添加到列表中(合并)A [1, 2]B [3, 4…

BatchFormer:有效提升数据稀缺场景的模型泛化能力|CVPR2022

文 | 侯志知乎&#xff08;已授权&#xff09;源 | 极市平台摘要当前的深度神经网络尽管已经取得了巨大的成功&#xff0c;但仍然面临着来自于数据稀缺的各种挑战&#xff0c;比如数据不平衡&#xff0c;零样本分布&#xff0c;域适应等等。当前已经有各种方法通过样本之间的关…

程序员面试金典 - 面试题 16.06. 最小差(排序+双指针)

1. 题目 给定两个整数数组a和b&#xff0c;计算具有最小差绝对值的一对数值&#xff08;每个数组中取一个值&#xff09;&#xff0c;并返回该对数值的差 示例&#xff1a; 输入&#xff1a;{1, 3, 15, 11, 2}, {23, 127, 235, 19, 8} 输出&#xff1a; 3&#xff0c;即数值对…

bigdecimal 保留两位小数_一起聊聊小数的储存和运算

原创&#xff1a; 蜀中亮子 玄说前端 小数运算的问题在 js 中的小数运算中&#xff0c;一直存在着一个问题&#xff0c;比如&#xff1a;0.10.20.30000000000000004 、0.4-0.30.10000000000000003。那么为什么会出现这种情况呢&#xff1f;这种情况又如何解决呢&#xff1f;为什…

从DeepFace到AdaFace,7篇论文讲清人脸识别

人脸识别是现在应用最广泛的视觉技术之一&#xff0c;同时也是前沿研究热点之一。我找来了深耕人脸的朋友张老师&#xff0c;从DeepFace到AdaFace&#xff0c;讲解deepface、facenet、vggface、sphereface、cosface、adaface等论文&#xff0c;给各位做一次人脸识别的系统分享。…

提升方法(Boosting)

文章目录1. 提升方法AdaBoost算法2. AdaBoost算法训练误差分析3. AdaBoost算法的解释4. 提升树5. sklearn 实例提升&#xff08;boosting&#xff09;方法是一种常用的统计学习方法&#xff0c;应用广泛且有效。 在分类问题中&#xff0c;它通过改变训练样本的权重&#xff0c…

在两个页面之间传递信息

在asp.net不同页面之间传值的方法主要有三种:(1)用querystring方法&#xff1a;在vs2005中新建asp.net网站(发送端)&#xff0c;在页面上添加button,两个TextBox,代码如下&#xff1a;protectedvoidButton1_Click(objectsender, EventArgs e) { string url; u…

英特尔或将大幅裁员

编辑 | David来源 | 新智元受PC业务持续不振影响&#xff0c;曝英特尔计划裁员数千人&#xff0c;可能将影响20%的员工。据知情人士透露&#xff0c;英特尔公司正计划大幅裁员&#xff0c;人数可能达到数千人&#xff0c;以削减成本&#xff0c;应对不景气的个人电脑市场的萎缩…

pandas object转float_25个Pandas实用技巧

本文一共为大家分享25个pandas技巧&#xff0c;此为上篇~显示已安装的版本输入下面的命令查询pandas版本&#xff1a;In [7]:pd.__version__Out[7]:0.24.2如果你还想知道pandas所依赖的模块的版本&#xff0c;你可以使用show_versions()函数:In [9]&#xff1a;pd.show_version…

LeetCode 820. 单词的压缩编码(后缀树)

文章目录1. 题目2. 解题2.1 反转字符串字符查找2.2 后缀树1. 题目 给定一个单词列表&#xff0c;我们将这个列表编码成一个索引字符串 S 与一个索引列表 A。 例如&#xff0c;如果这个列表是 ["time", "me", "bell"]&#xff0c;我们就可以将其…

sql查询分页

用sql 查询时select top 10 * from Orders order by orderid desc操作时&#xff0c;我们先对查询结果进行ordersby排序 然后才取出其最前边10个使用sql查询分页时的几点思路&#xff08;举例均从查询第100到120之间20条记录&#xff09;1.取前120条记录orderby主键&#xff0c…

openstack实例状态错误_Openstack虚机操作总结

1. 概览Openstack作为常见的IAAS服务&#xff0c;其最核心的对象就是虚机实例&#xff0c;而Openstack下支持的虚机操作有很多种&#xff0c;有些是特别常见的虚机操作比如创建虚机、启动虚机、删除虚机等&#xff0c;而有些虚机操作则是针对特定场景下比如出现故障而提供的保护…

神网站PaperWithoutCode:举报无法复现的论文,让一作社死??

文 | 小戏几乎是可以肉眼可见的看到机器学习领域的论文几何级的增长&#xff0c;在铺天盖地的论文雪花纸片般涌来时&#xff0c;灌水、可复现性、工作真实的意义这些概念也伴随着 Paper 的洪水进入了人们的视野。谈及科研&#xff0c;我们总是站在以往研究的基础上&#xff0c;…

仿WINDWS无限级Ajax菜单树升级1.3版(修补了严重BUG)

仿WINDWS无限级Ajax菜单树升级1.3版(修补了严重BUG) WINDWS无限级Ajax菜单树又升级了(1.3版) 对以下BUG进行了修复 1.只能在文字上拖拽(不能从文件夹图标上拖) 2.拖拽后不刷新菜单的BUG&#xff08;拖拽为子级菜单后&#xff0c;菜单原地不消失的情况。也…

程序员面试金典 - 面试题 08.11. 硬币(背包DP)

文章目录1. 题目2. 解题1. 题目 硬币。给定数量不限的硬币&#xff0c;币值为25分、10分、5分和1分&#xff0c;编写代码计算 n 分有几种表示法。(结果可能会很大&#xff0c;你需要将结果模上1000000007) 示例1:输入: n 5输出&#xff1a;2解释: 有两种方式可以凑成总金额:…

ab的plc跟西门子哪个好些_2020滚筒洗衣机哪个牌子好?想买滚筒洗衣机的看过来!...

滚筒洗衣机哪个牌子好&#xff1f;想买滚筒洗衣机的人越来越多&#xff0c;滚筒洗衣机无疑是现在大多数年轻人更喜欢的款式&#xff0c;颜值高、功能多、追求个性化洗衣操作&#xff0c;滚筒的不伤衣物更温柔对于有真丝雪纺面料衣物的&#xff0c;滚筒洗衣机现在真是越来越智能…

AI开始参与政治选举了??

编 | David 好困源 | 新智元让AI去参加议会选举&#xff0c;能成吗&#xff1f;一个丹麦政党让AI聊天机器人当了领袖&#xff0c;试图在议会中拿下一席&#xff0c;现距离20000个提名的门槛线仅差19988个了。现在的AI能干的事情太多了&#xff0c;写作文、画画、下棋、玩游戏&a…

Linux NAT设定

1&#xff1a;echo "1" >/proc/sys/net/ipv4/ip_forward 或vi /proc/sys/net/ipv4/ip_forward把0改为1&#xff0c;0表示IP FORWARDING功能是关闭&#xff0c;1表示开启。2&#xff1a;iptables -t nat -A POSTROUTING -o eth0 -s 192.168.0/24 -j MASQUERADE &a…

程序员面试金典 - 面试题 16.02. 单词频率(哈希表/Trie树)

文章目录1. 题目2. 解题2.1 哈希解法2.2 Trie树1. 题目 设计一个方法&#xff0c;找出任意指定单词在一本书中的出现频率。 你的实现应该支持如下操作&#xff1a; WordsFrequency(book)构造函数&#xff0c;参数为字符串数组构成的一本书get(word)查询指定单词在数中出现的…