Python查找数组公共元素的程序


以多维数组为例,有一种方法可以找到多维数组中存在的公共元素——intersection_update()。

此方法用于查找多维数组中存在的公共或相交元素。让我们考虑一个输入输出场景,然后继续进行编程。

输入输出场景

考虑一个本质上是多维的二维数组。

arr = [[1, 2, 3, 4], [3, 4, 5, 6], [7, 8, 3, 4], [4, 9, 8, 3], [4, 3, 10, 12]]
  • 上述数组包含5个子数组。

  • 我们可以清楚地观察到元素“3”和“4”存在于“arr”的所有子数组中。

  • 因此,元素“3”和“4”被认为是二维数组arr的公共元素。

示例

在这个示例中,我们将使用intersection_update()方法查找多维数组中存在的公共元素。

  • 考虑一个可以从中找到公共元素的二维数组。

  • 声明一个参数化方法,该方法可以将二维数组作为参数来查找公共元素。

  • 在方法中,用0初始化集合数组并将值赋给变量。

  • 使用循环遍历数组元素。

  • 借助intersection_update()方法,在遍历时依次查找公共元素。

def common_elements(arr):
   result = set(arr[0])
   for x in arr[1:]:
      result.intersection_update(x) 
   return list(result)
# main section
if __name__ == "__main__":

   arr = [[1, 2, 3, 4], [3, 4, 5, 6], [7, 8, 3, 4], [4, 9, 8, 3], [4, 3, 10, 12]]
   res = common_elements(arr)
   if len(res) > 0:
      print ("The common elements present within the array are: ",res)

   else:
      print ("There are no common elements present within the array !!")

输出

上述程序的输出如下:

The common elements present within the array are:  [3, 4]

查找两个不同数组中的公共元素

NumPy的intersect1d()方法可用于查找两个一维数组的公共元素。这类似于处理多维数组的intersect_update()方法。为了更好地理解这个概念,让我们来看一个例子。

输入输出场景

考虑两个本质上是一维的数组。

arr1 = [1, 2, 3, 4]
arr2 = [3, 4, 5, 6]
  • 我们可以清楚地看到元素“3”和“4”存在于数组arr1和arr2中。

  • 因此,我们可以得出结论,数组arr1和arr2的公共元素是3和4。

示例

在下面的示例中,我们将使用numpy模块的intersect1d()方法查找多个一维数组中存在的公共元素。

import numpy as n
arr1 = [1, 2, 3, 4]
print("The first array is: ")
print(arr1)
arr2 = [3, 4, 5, 6]
print("The second array is: ")
print(arr2)
narr1 = n.array(arr1)
narr2 = n.array(arr2)
print("The common elements within the given arrays are: ")
print(n.intersect1d(narr1, narr2))

输出

上述程序的输出如下:

The first array is:
[1, 2, 3, 4]
The second array is:
[3, 4, 5, 6]
The common elements within the given arrays are:
[3 4]

这样,根据数组的类型,可以遵循相应的步骤。如果考虑的数组是多维数组,则将遵循第一个程序中遵循的步骤。

如果考虑的数组是一维数组,则将遵循第二个程序中遵循的步骤。这就是查找一个或多个数组的公共元素的方法。

更新于:2023年5月5日

浏览量:166

开启你的职业生涯

完成课程获得认证

开始学习
广告