Python 中实现线性搜索算法

前些天发现了一个巨牛的人工智能学习网站,通俗易懂,风趣幽默,忍不住分享一下给大家。点击跳转到网站零基础入门的AI学习网站~。

前言

线性搜索算法,也称为顺序搜索算法,是一种简单但常用的搜索技术,用于查找特定元素是否存在于一个集合中。在本文中,将深入研究线性搜索算法,并演示如何在 Python 中实现它。将提供详细的算法描述、示例代码以及应用案例。

目录

前言

什么是线性搜索算法?

线性搜索算法的步骤

Python 中的线性搜索实现

示例:使用线性搜索查找元素

 示例 1:查找整数

 示例 2:查找字符串

 示例 3:查找自定义对象

应用案例:联系管理系统

总结


什么是线性搜索算法?

线性搜索算法是一种基本的搜索技术,用于查找目标元素是否存在于一个集合(通常是列表或数组)中。该算法的工作原理非常简单:它从集合的第一个元素开始逐个检查,直到找到目标元素或遍历完整个集合。

线性搜索算法适用于任何类型的数据,但它的效率相对较低,特别是当集合很大时。它的时间复杂度为 O(n),其中 n 是集合中元素的数量。因此,在处理大型数据集时,可能需要考虑使用更高效的搜索算法。

线性搜索算法的步骤

  1. 从集合的第一个元素开始,逐个检查每个元素。

  2. 检查当前元素是否等于目标元素。

  3. 如果找到目标元素,返回其位置(索引)。

  4. 如果遍历完整个集合仍未找到目标元素,表示目标元素不存在,返回一个特定的标记(如 -1)。

Python 中的线性搜索实现

下面是一个简单的 Python 函数,实现了线性搜索算法:

def linear_search(arr, target):for i, element in enumerate(arr):if element == target:return ireturn -1

上述函数接受两个参数:一个列表 arr 和一个目标元素 target 。它使用 enumerate 函数来遍历列表,并在找到目标元素时返回其索引,否则返回 -1。

示例:使用线性搜索查找元素

 示例 1:查找整数

numbers = [1, 3, 5, 7, 9, 11, 13]
target = 7result = linear_search(numbers, target)
if result != -1:print(f"{target} 在列表中的索引为 {result}")
else:print(f"{target} 未在列表中找到")

上述代码演示了如何在整数列表中查找目标元素 7,并返回其索引。

 示例 2:查找字符串

fruits = ["apple", "banana", "cherry", "date", "fig"]
target_fruit = "cherry"result = linear_search(fruits, target_fruit)
if result != -1:print(f"{target_fruit} 在列表中的索引为 {result}")
else:print(f"{target_fruit} 未在列表中找到")

这个示例展示了如何在字符串列表中查找目标字符串 "cherry",并返回其索引。

 示例 3:查找自定义对象

class Person:def __init__(self, name, age):self.name = nameself.age = agepeople = [Person("Alice", 25),Person("Bob", 30),Person("Charlie", 35)
]target_person = Person("Bob", 30)result = linear_search(people, target_person, key=lambda p: p.name)
if result != -1:print(f"{target_person.name} 在列表中的索引为 {result}")
else:print(f"{target_person.name} 未在列表中找到")

在这个示例中,定义了一个自定义对象 Person ,并在对象列表中查找一个具有特定属性的对象。

应用案例:联系管理系统

考虑一个实际的应用场景,使用线性搜索算法来实现一个简单的联系管理系统。用户可以添加联系人,并根据姓名查找联系人的详细信息。

class Contact:def __init__(self, name, phone_number):self.name = nameself.phone_number = phone_numbercontacts = []def add_contact(name, phone_number):contact = Contact(name, phone_number)contacts.append(contact)def find_contact(name):for contact in contacts:if contact.name == name:return contactreturn None# 添加联系人
add_contact("Alice", "123-456-7890")
add_contact("Bob", "987-654-3210")# 查找联系人
search_name = "Alice"
result_contact = find_contact(search_name)
if result_contact is not None:print(f"姓名: {result_contact.name}, 电话号码: {result_contact.phone_number}")
else:print(f"{search_name} 未在联系列表中找到")

在这个示例中,定义了一个 Contact 类来表示联系人,然后创建了一个联系人列表。用户可以使用 add_contact 函数添加联系人,并使用 find_contact 函数根据姓名查找联系人的详细信息。

总结

线性搜索算法是一种基本的搜索技术,适用于小型数据集或需要进行少量搜索操作的情况。尽管其效率相对较低(时间复杂度为 O(n)),但在某些情况下仍然非常有用。在实际应用中,可以根据需求选择适当的搜索算法,以提高效率。

本文提供了线性搜索算法的详细描述、Python 实现示例以及一个实际应用案例。希望这些信息能帮助dajia 理解线性搜索算法的工作原理,并在需要时有效地使用它。

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.hqwc.cn/news/469881.html

如若内容造成侵权/违法违规/事实不符,请联系编程知识网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

给定n个结点的树,其中有k个结点是特殊结点(未知),定义好结点:该结点到k个特殊结点的距离之和最小。若随机k个结点为特殊结点,求好结点个数的期望值

题目 思路&#xff1a; 举例&#xff1a; 其中黑色结点为特殊结点&#xff0c;可以看出&#xff0c;每种情况都有一个结点的s值不等于k / 2&#xff0c;但是是好结点&#xff0c;所以最后答案加一。 #include <bits/stdc.h> using namespace std; #define int long lon…

5种风格非常经典的免费wordpress主题

免费wordpress主题下载 高端大气上档次的wordpress主题&#xff0c;也可以是免费的&#xff0c;可以在线免费下载。 https://www.wpniu.com/themes/288.html wordpress免费主题 高端大气的wordpress免费主题&#xff0c;LOGO在顶部左侧&#xff0c;导航菜单在顶部右侧。 ht…

codechef121轮(A-G)

codechef121轮&#xff08;A-G)题解 ⭐️A.Leg Space 题目&#xff1a; &#x1f31f;题解&#xff1a; 很简单&#xff0c;比较就行 代码&#xff1a; #include <bits/stdc.h> using namespace std; int main() {// your code goes here int n,m;cin>>n>>…

(一)【Jmeter】JDK及Jmeter的安装部署及简单配置

JDK的安装和环境变量配置 对于Linux、Mac和Windows系统&#xff0c;JDK的安装和环境变量配置方法略有不同。以下是针对这三种系统的详细步骤&#xff1a; 对于Linux系统&#xff1a; 下载适合Linux系统的JDK安装包&#xff0c;可以选择32位或64位的版本。 将JDK的安装包放置…

error An unexpected error occurred: “https://registry.npm.taobao.org

背景&#xff1a; 想使用yarn命令结果报错 问题原因&#xff1a; 原来证书到期了 http://registry.npm.taobao.org/ 把这个放到浏览器搜索的时候自动换成https://registry.npmmirror.com/ 方案&#xff1a; npm cache clean --forcenpm config set registry https://registry…

惊艳网页(1):数码 智能硬件 电子科技类网站首屏

Hello&#xff0c;我是大千UI工场&#xff0c;专注UI设计8年的老司机&#xff0c;本期开始分享惊艳的网站页面&#xff0c;虽说现在网站需求量少了很多&#xff0c;但在很多行业还是必不可少的。 数码电子科技类网站的首屏设计应该能够吸引用户的注意力&#xff0c;展示网站的核…

算法学习——LeetCode力扣贪心篇1

算法学习——LeetCode力扣贪心篇1 455. 分发饼干 455. 分发饼干 - 力扣&#xff08;LeetCode&#xff09; 描述 假设你是一位很棒的家长&#xff0c;想要给你的孩子们一些小饼干。但是&#xff0c;每个孩子最多只能给一块饼干。 对每个孩子 i&#xff0c;都有一个胃口值 g[…

秒懂百科,C++如此简单丨第十九天:动态规划

目录 动态规划的初步理解 求最短路径数 洛谷 P1002 过河卒 题目描述 输入样例 输出样例 思路 AC Code 动态规划的初步理解 什么是动态规划&#xff1f;最直白的理解就是动态的规划。 那高级一点的理解呢&#xff1f;就是每时每刻都拿着一个小本本&#xff0c;也就是…

【C语言】解析刘谦春晚魔术《守岁共此时》

今年的春晚上刘谦表演了魔术《守岁共此时》&#xff0c;台上台下积极互动&#xff08;尤其是小尼&#xff09;&#xff0c;十分的有趣。刘谦老师的魔术不仅仅是他的高超手法&#xff0c;还有这背后的严谨逻辑&#xff0c;下面我们来用C语言来解析魔术吧。 源代码 #define _CRT…

【数据结构】哈希桶封装出map和set

利用之前的哈希桶封装出unordered_map和unordered_set。 这个封装并不简单&#xff0c;迭代器的使用&#xff0c;模板参数的繁多&#xff0c;需要我们一层一层封装。 map是一个k - v类型&#xff0c;set是k类型&#xff0c;那么就明确了如果需要封装&#xff0c;底层的tables…

【原创 附源码】Flutter集成Apple支付详细流程(附源码)

最近有时间&#xff0c;特意整理了一下之前使用过的Flutter平台的海外支付&#xff0c;附源码及demo可供参考 这篇文章只记录Apple支付的详细流程&#xff0c;其他相关Flutter文章链接如下&#xff1a; 【原创 附源码】Flutter集成谷歌支付详细流程(附源码) 【原创 附源码】F…

【前端高频面试题--虚拟DOM篇】

&#x1f680; 作者 &#xff1a;“码上有前” &#x1f680; 文章简介 &#xff1a;前端高频面试题 &#x1f680; 欢迎小伙伴们 点赞&#x1f44d;、收藏⭐、留言&#x1f4ac;前端高频面试题--虚拟DOM篇 虚拟DOM的理解虚拟DOM的解析过程为什么要用虚拟DOM虚拟DOM与真实DOM的…