数组对比,取出不同的值

1、比较两个数组中的值是否相同(该方法比较不了数组中的对象)
代码如下:

const  arr1 = [11,22,33]
const  arr2 = [11,22,33]
const  result = arr1.length === arr2.length && arr1.every(a => arr2.some(b => a === b)) && arr2.every(_b => arr1.some(_a => _a === _b));

2、取两个数组中不相同的元素(针对数组中的对象)
代码如下:

let arr = []
arr1 = [{name:’wang’,age:22}]
arr2 = [{name:’wang11’,age:22}]
arr1.map(r => {
	const d = arr2.find(u => (u.name.indexOf(r.name) > -1) &&  (u.name !== r.name))
	d && arr.push(d)
})

3、比较两个数组,取不同元素的值
代码如下:

const arr1 = ['aa','bb','cc']
const arr2 = ['aa','bb']

const getInfoArr = (arr1, arr2) => {
  let arr = []
  for(let i = 0; i < arr1.length; i++){
    let obj = arr1[i];
    let isExist = false;
    for(let j = 0; j < arr2.length; j++){
      let aj = arr2[j];
        if(obj == aj){
            isExist = true;
            break;
        }
    }
    if(!isExist){
      arr.push(obj);
    }
  }
  return arr;
}
  • 1
    点赞
  • 3
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
如果你有大量不同长度的数组进行对比,可以使用以下优化来提高代码的效率: 1. 对每个数组进行排序,这样可以方便后面的对比。 2. 对所有数组的长度进行排序,从短到长进行对比,这样可以尽早筛选出不符合要求的数组,减少后续对比的数量。 3. 使用 set 集合来存储每个数组中的元素,这样可以快速地进行元素是否存在的判断。 以下是一个示例代码: ```python # 假设你有多个数组,都保存在 arrays 变量中 arrays = [ [1, 2, 3, 4, 5], [3, 4, 5, 6, 7], [5, 6, 7, 8, 9] ] # 假设你想要填充的数字范围是 1 到 10 min_num = 1 max_num = 10 # 对每个数组进行排序 sorted_arrays = [sorted(array) for array in arrays] # 对所有数组的长度进行排序 sorted_lengths = sorted(range(len(arrays)), key=lambda i: len(arrays[i])) # 使用 set 集合来存储每个数组中的元素 elements = [set(array) for array in sorted_arrays] # 遍历所有数组的长度,从短到长进行对比 result = set() for i in sorted_lengths: if len(result) == max_num - min_num + 1: break for j in range(i + 1, len(arrays)): if len(result) == max_num - min_num + 1: break if not elements[i].isdisjoint(elements[j]): continue for num in sorted_arrays[i]: if num >= min_num and num <= max_num and num not in elements[j]: result.add(num) for num in sorted_arrays[j]: if num >= min_num and num <= max_num and num not in elements[i]: result.add(num) # 输出结果 print(sorted(list(result))) ``` 这个示例代码假设你有多个数组,并将它们存储在 `arrays` 变量中。你还指定了要填充的数字范围是 1 到 10。它对每个数组进行排序,并使用 set 集合来存储每个数组中的元素。然后对所有数组的长度进行排序,从短到长进行对比。在对比过程中,使用 isdisjoint 函数来判断两个数组是否有交集,如果没有交集,则继续进行对比。如果有交集,则跳过这两个数组的对比。如果一个数字在其中一个数组中出现,并且在另一个数组中不存在,则将它添加到结果集合中。最后输出结果。 请注意,由于我们使用了 Python 中的高级函数和数据结构,因此这段代码的运行效率较高。同时,由于我们按照数组长度从短到长进行对比,并使用 set 集合来存储元素,因此这段代码可以减少对比的数量,提高代码的效率。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值