如何使用异或(XOR)运算找到数组中缺失的数?

如何使用异或(XOR)运算找到数组中缺失的数?

今天给大家分享一篇关于使用XOR(异或)运算找到数组中缺失的数的问题。

在一次Javascript面试中,有这么一个问题:

假设有一个由0到99(包含99)的整数组成的长度为100的数组。从数组中随机移除一个元素,得到了一个长度为99的数组,那么请问如何找到所取出的数字是几?(假设数组未排序)。

大多数面试者都是按照如下方法解答的:

首先对数组进行排序,然后遍历一遍数组,检查数组中相邻两项的的差,如果差大于1,则找到缺失的数字。

这是一种有效的算法。但是由于涉及排序,会消耗额外的计算成本。所以问题在于如何在只遍历一遍数组的情况下找到缺失的数。

第一种解法

计算剩余99个整数的和,以及0-99所有整数的总和,就可以用0-99之间所有整数的总和减去数组中剩余数的和来得到缺少的数。

第二种解法

通过对所有整数[0..99]的进行XOR,然后将得到的结果对剩余数组中所有项的进行异或。

更多详细内容可以查看原文。今天的文章就分享到这啦。

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。

推荐阅读更多精彩内容

  • 算法思想贪心思想双指针排序快速选择堆排序桶排序荷兰国旗问题二分查找搜索BFSDFSBacktracking分治动态...
    第六象限阅读 3,272评论 0 0
  • 第5章 引用类型(返回首页) 本章内容 使用对象 创建并操作数组 理解基本的JavaScript类型 使用基本类型...
    大学一百阅读 3,270评论 0 4
  • 1. 找出数组中重复的数字 题目:在一个长度为n的数组里的所有数字都在0到n-1的范围内。数组中某些数字是重复的,...
    BookThief阅读 1,815评论 0 2
  • 每个人对于“全部”的理解是不同的。 在那些没有概率常识的人眼里,所谓的全部就是倾家荡产,毫无保留。 但是如果我们掌...
    四维剑阅读 115评论 0 1
  • 写在前面:你现在的状态是怎样的?每天朝九晚五按时上下班?回家躺尸?刷微博微信到深更半夜?每天的乐趣就是看看综艺节目...
    杏林医者Dr张阅读 962评论 3 5