Python程序搜索元组中的元素


在Python中,搜索数据结构中的元素是一项常见任务,不同类型的数据结构应该旨在提供有效的搜索方法。搜索问题涉及在容器中查找特定元素,如果未找到则返回一个值。

元组是一种可用于此任务的数据结构,它将不同类型的数据集合存储在一个变量中。这些项目可以通过其索引访问,Python提供了各种方法来处理它们。元组是不可变的,这意味着一旦创建,就不能修改。对元组执行的任何操作都将导致一个包含更新值的新元组。

我们可以使用圆括号括住要存储的数据来在python中定义元组 -

var = (1, 'a', 3.7)

每当我们需要检查项目是否存在于元组中时,我们必须寻找在其中搜索该项目的方法。幸运的是,python为我们提供了解决此问题的方法。下面列出了一些我们可以确定元素是否存在于元组中的方法。

  • 使用python的for循环

  • 使用python的in运算符

  • 使用元组对象的index方法

使用python的for循环

Python为我们提供了多种遍历元组、列表等的方法。通过使用循环,我们将遍历元组的所有元素。在每次迭代中,我们将检查当前元素是否等于我们要搜索的元素。

如果匹配,我们将使用元素已找到的消息退出循环,如果我们遍历所有元素并且仍然找不到元素,我们将打印未找到的消息

算法

让我们看看上述方法的算法 -

步骤1 - 创建一个元组

步骤2 – 创建一个计数器变量来跟踪元素找到或未找到的状态

步骤3 – 使用for循环开始迭代元素

步骤4 – 使用比较运算符和if语句检查当前值是否等于我们要搜索的值。

步骤5 – 如果是,则我们找到了元素,将found设置为true,并退出循环

步骤6 – 如果否,则继续下一个元素

步骤7 – 程序退出循环后,检查计数器变量的值是否为true

步骤8 – 如果是,则打印元素已找到

步骤9 – 如果否,则打印元素未找到

示例

在这个例子中,我们使用for循环迭代列表并比较每个元素与给定的数字,如果元素等于给定的数字,我们中断for循环并打印该元素存在。

A = (1, 2, 3, 4, 6)
isFound = False
elem = 5
for item in A:
   if item == elem:
      isFound = True
      break
   if isFound:
      print("Element found")
   else:
      print("Element not found")

输出

Element not found
Element not found
Element not found
Element not found
Element not found

使用in运算符

in运算符确定给定值是否是字符串、数组、列表或元组等序列的组成元素。

Python为检查元素是否存在于可迭代对象中(在本例中为元组)的问题提供了一个简单的解决方案。那就是“in”运算符。它是python的内置方法,其功能与我们上面讨论的方法相同,但它会产生布尔值。

也就是说,如果我们要搜索的项目存在于可迭代对象(在本例中为元组)中,它将返回true,如果元素不存在,则表达式将返回False。使用in运算符的语法如下 -

ElementToSearch in VariableToSearchIn

示例

以下是一个使用in运算符在数组中搜索元素的示例。在这里,我们使用了python的in运算符,它检查元素是否存在于数据结构中。

如果此运算符返回true,则表示该项目存在,我们返回元素存在。如果运算符返回false,我们返回元素未找到。

array = ("mango", "banana", "apple", "orange")
elem = "mango"
if elem in array:
   print ("Element found")
else:
   print ("Element not found")

输出

Element found

使用元组的index()方法

我们可以通过以下方式访问元组的元素:tuple_name[index]

正如我们已经讨论的那样,元组是python中的预定义类,因此它有几种可用于执行简单任务的方法。其中一种方法是index方法。

它将要搜索的值作为输入,并在元素存在的情况下返回该元素第一次出现时的索引作为返回值,如果元素不存在,则引发异常。

由于存在可能引发异常,我们将使用try和except块进行错误处理。

示例

在下面的示例中,我们使用了index()函数来获取给定数字的索引,如果它给出了索引,我们打印元素已找到,否则,我们打印“元素未找到”。

input_array = (1, 2, 3, 5, 6, 7)
elem = 4
try:
   A.index(elem)
   print("Element found")
except:
   print("Element not found")

输出

Element not found

结论

在本文中,我们重点介绍了三种在元组中搜索元素的不同方法。我们学习了如何使用for循环、使用in运算符以及使用元组类的index方法。

更新于:2023年2月20日

5K+ 浏览量

开启你的职业生涯

通过完成课程获得认证

开始学习
广告