算法:如何从三个有序数组中找出他们的公共元素

1.给定以非递减排序的三个数组,找出这三个数组中的所有公共元素,例如,给出三个数组,arr1 = [,2,5,12,20,45,85],arr2=[16,19,20,85,200],arr3=[3,4,15,20,39,72,85,190],那么这三个数组的公共元素为[20,85]
2.解析:方法一,可以找出两个数组的交集存为临时数组,再求临时数组与第三个数组的交集。方法二:假设当前遍历的三个数组元素分别为arr1[i],arr2[j],arr3[k],则存在以下几种可能性,
(1)如果arr[i],arr2[j],arr3[k]相等,则说明当前遍历的元素是三个数组的公共元素,可以直接打印出来,然后i,j,k加一,使三个数组同时向后移动,此时继续遍历各个数组后面的元素
(2)如果arr1[i]<arr2[j],则执行i+来继续遍历arr1后面的元素
(3)如果arr2[j]<arr3[k],j+来向后遍历
(4)如果前面条件都不满足,则说明arr1[i]>arr2[j]而且arr2[j]>arr3[k],则k+继续遍历
3.代码如下:

def find_commen(arr1,arr2,arr3):
    i,j,k = 0,0,0
    while i <len(arr1) and j < len(arr2) and k < len(arr3):
        if arr1[i] == arr2[j] == arr3[k]:
            print(arr1[i])
            i += 1
            j += 1
            k += 1
        elif arr1[i] < arr2[j]:
            i += 1
        elif arr2[j] < arr3[k]:
            j += 1
        else:
            k += 1
if __name__ == '__main__':
    arr1 = [2,5,12,20,45,85]
    arr2 = [16,19,20,85,200]
    arr3 = [3,4,15,20,39,72,85,190]
    find_commen(arr1,arr2,arr3)

结果
20
85
  • 0
    点赞
  • 5
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值