Python算法——如何从三个有序数组中找出公共元素

要求:

给定以非递减顺序排序的三个数组,找出这三个数组的公共元素。如ar1 = [2,5,12,20,45,85],ar2 = [16,19,20,85,200], ar3 = [3,4,15,20,39,72,85,190],那么其公共元素为[20,85]。

分析:

       假设当前遍历的三个数组元素分别为ar1[i]、ar2[j]、ar3[k],则存在以下几种可能性:

        (1)如果ar1[i]、ar2[j]、ar3[k]相等,则说明当前遍历的元素是三个数组的公共元素,可以直接打印出来,然后通过执行i+,j+,k+,使得三个数组同时向后移动,此时继续遍历各数组后面的元素。

       (2)如果ar1[i]<ar2[j],则执行 i+ 来遍历ar1中后面的元素,因为ar1[i] 不可能是三个数组的公共元素。

       (3)如果ar2[j]<ar3[k],同理可以通过 j+ 来遍历ar2后面的元素。

       (4)如果前面的条件都不满足,说明ar1[i]>ar2[j]而且ar2[j]>ar3[k],此时可以通过 k+ 来继续遍历ar3后面的元素。

实现代码:

# -*- coding:utf-8 -*-
def findCommon(ar1,ar2,ar3):
    i = 0
    j = 0
    k = 0
    n1 = len(ar1)
    n2 = len(ar2)
    n3 = len(ar3)
    #遍历三个数组
    while i < n1 and j < n2 and k < n3:
        #找到了公共元素
        if ar1[i] == ar2[j] and ar2[j] == ar3[k]:
            print(ar1[i],'',end="")
            i += 1
            j += 1
            k += 1
        #ar1[i]不可能是公共元素
        elif ar1[i] < ar2[j]:
            i += 1
        #ar2[j]不可能是公共元素
        elif ar2[j] < ar3[k]:
            j += 1
        #ar3[k]不可能是公共元素
        else:
            k += 1

if __name__ == "__main__":
    ar1 = [2, 5, 12, 20, 45, 85]
    ar2 = [16, 19, 20, 85, 200]
    ar3 = [3, 4, 15, 20, 39, 72, 85, 190]
    findCommon(ar1,ar2,ar3)

运行结果:

20 85 

性能分析:

       时间复杂度为O(N1+N2+N3)。

 

 

  • 1
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值