繁体   English   中英

比较两个长度相同的数组的相同索引

[英]Compare same index of two array having same length

我有两个长度相同的数组

array1 = [12,13,14,15,16]
array2 = [22,32,45,11,7]

现在我只想比较 javasacript ex 中 for 循环中相同的索引值:

array1[0] < array2[0]
array1[1] < array2[1]
array1[2] < array2[2]

如果array1[index]值小于array2[index]则返回true

我想输出必须是一个boolean数组。 为此,您可以通过传递callback函数来使用map方法。

 array1 = [12,13,14,15,16] array2 = [22,32,45,11,7] result = array1.map(function(item, i){ return item < array2[i]; }); console.log(result);

或者简单地使用arrow函数。

 array1 = [12,13,14,15,16], array2 = [22,32,45,11,7] result = array1.map((item, i) => item < array2[i]); console.log(result);

如果您想返回10值,您可以使用+运算符来force结果为数字原始类型。

result = array1.map(function(item, i){
  return + (item < array2[i]);
});

如果您想接收带有布尔值的数组,该值指示值是较低还是较高,请尝试以下操作:

var result = [];
for(var i = 0; i < array1.length;i++){
    result.push(array1[i] < array2[i]);
}

试试这个:

  array1 = [12,13,14,15,16];
  array2 = [22,32,45,11,7];
  for(var x = 0; x < array1.length; x++) {
      if(array1[x] < array2[x]) {
          //do something
      }

  }

如果我理解您的问题的意思,这称为词典比较,并且是其他语言(例如 Python 或 C++)中内置的数组。

在 Javascript 中存在字符串,但您必须自己为数组实现它,例如

// lexical less-than-or-equal
function lex_leq(a, b) {
    let i = 0, na = a.length, nb = b.length, n = Math.min(na, nb);
    while (i<n && a[i] === b[i]) i++; // skip over equals
    return i === na || (i !== nb && a[i] < b[i]);
}

其他排序可以通过类似的代码或重用相同的实现来计算......例如(a<b)等价于!(b<=a)

a1 = [12,13,14,15,16]
a2 = [22,32,45,11,7]
result = a1.map(function(item, i){
return item < a2[i];
});
console.log(result);

试试这个解决方案。 这将告诉您哪个索引不匹配。

 var array1 = [12,13,14,15,16]; var array2 = [12,13,14,15,34]; function compareArray(arr1, arr2) { if(arr1.length !== arr2.length) return false; return arr1.reduce(function(acc, val, index) { acc.push(val === arr2[index]); return acc; }, []); } var response = compareArray(array1, array2); console.log(response);

 array1 = [12,13,14,15,16] array2 = [22,32,45,11,7] result = [] array1.map(function(item, i){ result[i] = item < array2[i]; }); console.log(result);

暂无
暂无

声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM