使用 JavaScript 查找数组元素的 OR 和 AND
在 JavaScript 中,我们可以使用“&&”运算符在两个元素之间进行 AND 运算,使用“||”运算符在两个元素之间进行 OR 运算。
在这里,我们将学习在数组的每个元素之间执行 OR 和 AND 运算。
使用for循环
我们可以使用 for 循环来迭代数组元素,并对数组元素与结果元素进行 OR 运算。
语法
用户可以按照下面的语法使用for循环对每个元素进行OR或AND运算。
for () { result = result || array[i]; }
在上面的语法中,“结果”是前 i-1 个元素的 OR 运算的结果值。
示例 1
在下面的示例中,我们创建了数字数组。之后,我们通过传递数组及其长度作为参数来调用 PerformOR() 函数。
我们定义了“结果”变量并将其初始化为零。之后,我们使用 for 循环来遍历数组元素。在 for 循环中,我们对数组元素与“result”变量的值执行 OR 运算。
在输出中,用户可以观察所有数组元素进行或运算的结果值。
<html> <body> <div id = "output"> </div> <script> let output = document.getElementById('output'); function performOR(array, n) { let result = 0; for (let i = 0; i < n; i++) { result = result || array[i]; } return result; } let numbers = [1, 2, 3, 4, 5, 6, 7, 8]; output.innerHTML += "Array: "+ JSON.stringify(numbers); output.innerHTML += "<br>" output.innerHTML += "Result of OR Operation of all elements of above array: " + performOR(numbers, numbers.length); </script> </body> </html>
示例 2
在下面的示例中,我们对每个数组元素执行 AND 运算。首先,我们用第一个数组元素初始化结果变量。之后,我们使用for循环从第二个数组元素开始迭代,并将数组元素与result变量的值进行AND运算。
<html> <body> <h3> Using the <i> for loop </i> to perform AND operation for all array elements in JavaScript </h3> <div id = "output"> </div> <script> let output = document.getElementById('output'); function performAND(array, n) { let result = array[0]; for (let i = 1; i < n; i++) { result = result && array[i]; } return result; } let num = [10, 30, 20, 40, 50]; output.innerHTML += "Array: "+ JSON.stringify(num ); output.innerHTML += "<br>" output.innerHTML += "Result of AND operation of all elements of the above array: " + performAND(num, num.length); </script> </body> </html>
使用 While 循环
while 循环对于像 for 循环一样迭代数字数组也很有用。在迭代数组元素时,我们可以对单个数组元素与结果变量执行 AND 或 OR 运算。
语法
用户可以按照下面的语法使用while循环来查找数组元素的OR和AND。
while (n--) { result = result && array[n]; }
在上面的语法中,结果变量包含数组元素进行 OR 和 AND 运算的结果值。
示例 3
在下面的示例中,我们使用 while 循环和“&&”运算符来查找所有数组元素的 AND。我们使用数组的最后一个元素初始化了结果变量。之后,我们在每次迭代中将 n 的值减 1,并将数组元素与结果变量的值进行 AND 运算。
<html> <body> <h3> Using the <i> while loop </i> to perform AND operation for all array elements in JavaScript </h3> <div id = "output"> </div> <script> let output = document.getElementById('output'); function performAND(array, n) { let result = array[n]; while (n--) { result = result && array[n]; } return result; } let array = [2, 3]; output.innerHTML += "The AND operation of all elements of " + array + " is " + performAND(array, array.length - 1); </script> </body> </html>
使用 Array.reduce() 方法
array.reduce() 将数组缩减为单个结果值。在这里,我们可以减少数组,这样我们就可以得到所有数组元素的 AND 或 OR。
语法
用户可以按照下面的语法使用 array.reduce() 方法来查找所有数组元素的 AND 或 OR。
array.reduce((res, current) => res || current, 0);
示例 4
在下面的示例中,performOR() 函数返回所有数组元素的或。在函数中,我们使用了reduce()方法来减少数组并对所有元素进行或运算。
在输出中,用户可以观察所有元素的 OR 结果值。
<html> <body> <h3> Using the <i> array.reduce() </i> method to perform OR operation for all array elements in JavaScript </h3> <div id = "output"> </div> <script> let output = document.getElementById('output'); function performOR(array) { return array.reduce((res, current) => res || current, 0); } let num = [10, 30, 20, 40, 50]; output.innerHTML += "The AND operation of all elements of " + JSON.stringify(num) + " is " + performOR(num); </script> </body> </html>
示例 5
在此示例中,我们使用 array.reduce() 方法对所有数组元素进行 AND 运算。我们将回调函数作为 array.reduce() 方法的第一个参数传递,并将第一个数组元素作为第二个参数,表示“res”变量的初始值。 ‘res’变量包含数组元素AND运算的最终值。
<html> <body> <h3> Using the <i> array.reduce() </i> method to perform AND operation for all array elements in JavaScript </h3> <div id = "output"> </div> <script> let output = document.getElementById('output'); function performAND(array) { return array.reduce((res, current) => res && current, array[0]); } let num = [4, 5]; output.innerHTML += "The AND operation of all elements of " + JSON.stringify(num) + " is " + performAND(num); </script> </body> </html>
结论
用户学会了查找数组元素的 AND 或 OR。在第一种方法中,我们使用了 for 循环,在第二种方法中使用了 while 循环。在第三种方法中,我们使用了 array.reduce() 方法,这是更具可读性的代码。