我们给了一个整数数组,并告诉我们所有元素出现一个偶数次,除了单个元素。我们的工作是在单次迭代中找到该元素。
让它成为样本数组-
[1, 4, 3, 4, 2, 3, 2, 7, 8, 8, 9, 7, 9]
在尝试此问题之前,我们需要了解一些按位XOR(^)运算符。
如果两个操作数彼此互补,则XOR运算符返回TRUE;如果两个操作数相同,则返回FALSE。
TROR TABLE OF XOR()运算符-
0 ^ 0 → 0 0 ^ 1 → 1 1 ^ 0 → 1 1 ^ 1 → 0
如果我们仔细检查这种行为,我们会注意到,当XOR运算符用于完全相同的值(例如12 ^ 12)时,它总是返回FALSE或0,换句话说,它可以用于否定使偶数出现的值的时间。这正是我们想要的。
因此,在下面的代码中编写相同的内容-
const sampleArray = [1, 4, 3, 4, 2, 3, 2, 7, 8, 8, 9, 7, 9]; console.log(sampleArray.reduce((a, b) => a ^ b));
它遍历每个元素,并保持否定外观均匀的元素,并返回唯一出现奇数次的元素。
输出结果
控制台输出将是-
1