![](/img/trans.png)
[英]Compare two arrays with same length but having different object id's inside in JS
[英]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);
如果您想返回1
或0
值,您可以使用+
运算符来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.