【Python数据结构与算法】—— 搜索算法 | 期末复习不挂科系列

🌈个人主页: Aileen_0v0
🔥系列专栏: 数据结构与算法
💫个人格言:"没有罗马,那就自己创造罗马~"


这篇博客主要探索的是计算机科学常见问题---搜索算法

“时间紧,任务重!”

话不多说,开始今天的学习之旅吧⛵~


目录

搜索

定义

关键字-in

顺序搜索 

无序表的顺序搜索过程

无序表的顺序搜索代码实现 

分析顺序搜索算法

有序列表

有序列表的顺序搜索过程​编辑

无序表的顺序搜索代码实现 


搜索

定义

搜索是指从元素集合中找到特定元素算法过程

搜索过程通常返回True 或 False 来表示元素是否在集合中。

有时也可以修改搜索过程,使它返回目标元素的位置。

为了更好的打好算法基础,我们这次先探索搜索的元素是否存在这一问题。


关键字-in

in是Python中的关键字,用于判断一个元素是否存在于一个容器中。可以用于列表、元组、字典、集合等数据类型。它可以被用于for循环语句 和 if语句中。

我们之前做Python每日一练时我曾科普过Python中 我们可以通过运算符 —— in 去检查元素是否在列表中。

print(15 in [1,2,3])
print(15 in [1,2,3,15])

运行结果: 


顺序搜索 

线性结构(数组、链表、栈、队列等)都有下标。每个数据项都有一个相对于其它数据项的位置。

Python的列表 ,数据项的位置就是其下标。

因为下标有序的,So 我们能够进行 顺序访问顺序搜索

无序表的顺序搜索过程

下图展示了顺序搜索的过程。

无序表的顺序搜索代码实现 

def sequential_search(a_list,item):pos = 0while pos < len(a_list):if a_list[pos] == item:return  Truepos += 1return  Falseprint(sequential_search([1,2,4,5,9],5))

从列表第一个元素开始, 沿着下表顺序逐个查看,直到找到目标元素或者到达列表末尾。

若查完列表后仍未找到目标元素,则说明目标元素不在列表中。

分析顺序搜索算法

分析搜索算法前,首先需要先定义 计算的基本单元---解决问题过程中不断重复的的某一步

对搜索来说,记录 比较的次数 是合理的 性能指标。

每次比较只有两个结果: 找到目标元素,或未找到。

假设元素排列无序,则目标元素在每一个位置出现的可能都相同。

确定目标元素是否在列表中,唯一的方法就是将它与列表中的每个元素都比较一次

列表中有n个元素,那么顺序搜索经过 n 次比较后才能确定目标元素不在列表中。如果列表含目标元素,分析起来更复杂。实际上有 3 种可能的情况:

最好情况目标元素位于列表的第一个位置,则只需比较一次;

最坏情况目标元素位于最后一个位置,则需要比较 n次

平均情况目标元素位于中间位置,则需要比较 n / 2次。 --> 当n增大,系数则可省略,所以顺序搜索时间复杂度O(n)


有序列表

有序列表的顺序搜索过程

通过观察上图有序列表列表中的顺序搜索过程我们可以得出以下结论:

元素按升序排列

如果存在目标元素,那么它出现在 n个位置中任意一个位置的可能性仍然一样大,因此比较次数与在无序列表相同

But,如果不存在目标元素,那么搜索效率就会提高。---> 因为当找到比目标元素大的数的时候程序就会停止搜索

无序表的顺序搜索代码实现 

#有序表的顺序搜索
def ordered_sequential_search(a_list,item):pos = 0while pos < len(a_list):if a_list[pos] == item:return Trueelif a_list[pos] > item:return Falsepos += 1return False
print(ordered_sequential_search([1,2,4,5,9],6))

下表总结了,在有序表中搜索时的比较次数。

最好情况:只需比较1次。  平均情况比较 n / 2 次,但时间复杂度仍是O(n)。

总结:只有当列表不存在目标元素时,有序排列的元素,才能提高顺序搜索的效率

📝总结:

本篇文章介绍了搜索算法以及,有序列表在搜索算法中 的优势,前提条件是:只有当元素不在列表中时有序排列的元素,才能提高顺序搜索的效率

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

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

相关文章

HarmonyOS--ArkTS(0)--目录

官方API文档&#xff1a; HarmonyOS应用开发官网 - 华为HarmonyOS打造全场景新服务 华为开发者官方网站_创新从这里开始

MySQL的锁机制

1.简介 MySQL的隔离性是由锁机制来保证的。锁是计算机协调多个进程或线程并发地访问某一资源你的机制。当多线程并发地访问某个数据时&#xff0c;尤其是在涉及金钱等安全敏感性数据的时候&#xff0c;需要保证数据在任意时刻最多只有一个线程可以对其进行修改&#xff0c;从而…

Android 分享小结

关于作者&#xff1a;CSDN内容合伙人、技术专家&#xff0c; 从零开始做日活千万级APP。 专注于分享各领域原创系列文章 &#xff0c;擅长java后端、移动开发、商业变现、人工智能等&#xff0c;希望大家多多支持。 目录 一、导读二、微信 分享 三、 QQ 、QQ空间&#xff08;Qz…

MATLAB基础运算

矩阵和数字相乘 就是矩阵里面每个元素跟这个数字乘一遍&#xff0c;无论是点乘还是叉乘&#xff0c;对于这个都一样。 >> Aones(3) A 1 1 11 1 11 1 1 >> 10*A ans 10 10 1010 10 1010 10 10 矩阵和矩阵叉乘 能不能相…

基于ssm铁岭河医院医患管理系统论文

摘 要 21世纪的今天&#xff0c;随着社会的不断发展与进步&#xff0c;人们对于信息科学化的认识&#xff0c;已由低层次向高层次发展&#xff0c;由原来的感性认识向理性认识提高&#xff0c;管理工作的重要性已逐渐被人们所认识&#xff0c;科学化的管理&#xff0c;使信息存…

logback的使用

1 logback概述 SLF4J与其它日志组件调用关系图如下所示。 SLF4J&#xff0c;即Java中的简单日志门面&#xff08;Simple Logging Facade for Java&#xff09;&#xff0c;不是具体的日志解决方案&#xff0c;它只服务于各种各样的日志系统。 SLF4J最常用的日志实现框架是&am…

2023 CCF中国软件大会(CCF ChinaSoft) “区块链可靠性分析”论坛成功召开

2023年12月1日上午&#xff0c;2023年度CCF中国软件大会区块链可靠性分析论坛成功召开。 本次论坛由中山大学郑子彬、澳门科技大学张涛、中科院软件所蔡彦和中山大学陈嘉弛四位老师联合组织举办。本论坛重点关注区块链可靠性&#xff0c;邀请了近年来在区块链可靠性研究方面有先…

【postgresql】ERROR: INSERT has more expressions than target columns

执行下面sql insert into apply_account_cancellation3 select * from pply_account_cancellation; 返回下面错误信息 insert into apply_account_cancellation3 select * from apply_account_cancellation > ERROR: INSERT has more expressions than target colu…

Java:字节流 文件输出与读入方法 并 实现文件拷贝

文章目录 字节 流FileOutputStream换行 与 续写FileInputstream实现 文件拷贝&#xff08;字节数组 读入方法&#xff09;字节流 编码 字节 流 FileOutputStream 创建对象&#xff0c;指定位置&#xff08;产生数据传输通道&#xff09; 参数可以是File对象&#xff0c;也可以…

特征驱动开发

FDD 方法来自于一个大型的新加坡银行项目。FDD 的创立者 Jeff De Luca 和 Peter Coad 分别是这个项目的项目经理和首席架构设计师。在 Jeff 和 Peter 接手项目时&#xff0c;客户已经经历了一次项目的失败&#xff0c;从用户到高层都对这个项目持怀疑的态度&#xff0c;项目组士…

mysql面试题——日志

一&#xff1a;为什么需要REDO日志 缓冲池可以帮助我们消除CPU和磁盘之间的鸿沟&#xff0c;checkpoint机制可以保证数据的最终落盘&#xff0c;然而由于checkpoint 并不是每次变更的时候就触发 的&#xff0c;而是master线程隔一段时间去处理的。所以最坏的情况就是事务提交后…

持续集成交付CICD:Jenkins配置Nexus制品发布

目录 一、实验 1.Jenkins配置Nexus制品发布 一、实验 1.Jenkins配置Nexus制品发布 &#xff08;1&#xff09;策略 发布其实就是下载制品&#xff0c;然后将制品发送到目标主机&#xff0c;最后通过脚本或者指令启动程序。 &#xff08;2&#xff09;安装Maven Artifact …

uniapp图片预览

用的是Uview组件库里面的 直接在页面写上&#xff1a; <u-album singleSize"100" :urls"[https://lxt.jingyi.icu/item.img]"></u-album> 这图片路径是我自己的 你们可以按照组件库里面的方法去实现

DataFrame的使用

查看数据类型及属性 # 查看df类型 type(df) # 查看df的shape属性&#xff0c;可以获取DataFrame的行数&#xff0c;列数 df.shape # 查看df的columns属性&#xff0c;获取DataFrame中的列名 df.columns # 查看df的dtypes属性&#xff0c;获取每一列的数据类型 df.dtypes df.i…

标准成本核算基础知识 – 了解间接费用成本流程 - Part4

原文地址&#xff1a;Basics of Standard Costing – Understanding overhead cost flow-Part 4 | SAP Blogs 这是我理解标准成本计算及其流程的另一篇文档的延续。 标准成本核算基础知识 - 了解成本构成结构 - 第 3 部分 管理费用是只能间接归因于产品的成本&#xff0c;例如…

react中使用react-konva实现画板框选内容

文章目录 一、前言1.1、API文档1.2、Github仓库 二、图形2.1、拖拽draggable2.2、图片Image2.3、变形Transformer 三、实现3.1、依赖3.2、源码3.2.1、KonvaContainer组件3.2.2、use-key-press文件 3.3、效果图 四、最后 一、前言 本文用到的react-konva是基于react封装的图形绘…

基础课20——从0-1客服机器人生命周期

温馨提示&#xff1a;篇幅较长&#xff0c;可点击目录查看对应节点。 1.机器人搭建期 搭建机器人包含&#xff1a;素材整理、问题提炼、相似问题补充、答案编辑、问题分配引擎等等步骤&#xff0c;不同厂商可能有所区别&#xff0c;但关键功能的实现离不开以下步骤。 1.1素材…

《形式语言与自动机理论(第4版)》笔记(三)

文章目录 [toc]前导《形式语言与自动机理论&#xff08;第4版&#xff09;》笔记&#xff08;一&#xff09;《形式语言与自动机理论&#xff08;第4版&#xff09;》笔记&#xff08;二&#xff09; 第四章&#xff1a;正则表达式4.1|启示4.2|正则表达式的形式定义正则表达式性…

排序算法之四:直接选择排序

1.基本思想 每一次从待排序的数据元素中选出最小&#xff08;或最大&#xff09;的一个元素&#xff0c;存放在序列的起始位置&#xff0c;直到全部待排序的数据元素排完 。 2.直接选择排序 在元素集合array[i]--array[n-1]中选择关键码最大(小)的数据元素 若它不是这组元素中的…

ssm的健身房预约系统(有报告)。Javaee项目。ssm项目。

演示视频&#xff1a; ssm的健身房预约系统&#xff08;有报告&#xff09;。Javaee项目。ssm项目。 项目介绍&#xff1a; 采用M&#xff08;model&#xff09;V&#xff08;view&#xff09;C&#xff08;controller&#xff09;三层体系结构&#xff0c;通过Spring Spring…