【算法与数据结构】4 算法利器,详解循环不变量与复杂度分析

简介: 【算法与数据结构】4 算法利器,详解循环不变量与复杂度分析

一、前情回顾

👉传送门:1 详解线性查找法

👉传送门:2 线性查找的优化

👉传送门:3 线性查找的测试

二、循环不变量

✳️循环是程序设计中非常重要的一种构建逻辑的方式,我们总是要循环的去做一件事情,逐渐的把算法想求解的问题给求解出来


1.通俗解析线性查找循环代码

对于前面学习的线性查找,只有一个重复循环:要做的是每一轮循环中确认一下data[i]是否是目标,如果data[i]和target是相等的,就把i给return回去,否则的话就继续进行这个循环

循环体中只有一个if语句,这个if语句执行完以后,相当于在这一轮循环中确认出了data[i]不是我们的目标,然后就进行下一次的循环

在每轮循环循环结束的时候能确定data[0…i]中没有找到我们的目标

public static <E> int search(E[] data, E target){

for(int i = 0; i < data.length; i ++)

 if(data[i].equals(target))

  return i;

return -1;

   }

1

2

3

4

5

6

2.线性查找循环的开始/末尾

微信图片_20230701104245.png


1️⃣在循环开始的时候,满足一个条件:data[0…i-1]没有找到目标


2️⃣当i等于0的时候,i-1就是-1——这个区间不存在,所以没有找到目标


3️⃣然后我们来判断data[0]是否是目标,如果data[0]不是目标的话,i++在下一轮循环中i变成了1,在i==1这轮循环开始的时候,i-1=0,也就是从0到0这一段区间中没有找到目标,相应的我们来判断data[1]是否是目标


4️⃣还不是目标的话,i++后,i就变成了2,i-1=1,也就是在i==2这轮循环开始的时候,从0到1这一段区间中没有找到目标

… …


✔️循环开始的时候 ,data[0…i-1]这段区间中没有找到目标,整个循环体是判断data[i]是否是目标


🟢如果data[i]是目标,return i

🔴如果不是目标,那么在这个循环末尾的时候就说明data[0…i]都没有找到目标

i++操作后,到了下一轮循环中,下一轮循环的i-1就是上一轮循环结束时的i

3.循环不变量的真面目

3.1 什么是循环不变量

✳️循环不变量其实就是指在每一轮循环开始的时候算法都满足这样的性质:对于上面的线性查找法来说,在每一轮循环开始的时候,都满足data[0…i-1]区间中没有目标target, 区间也可以表示data[0…i),这两种表示方法是等价的,循环每一轮开始的时候都一定是满足这样的一个条件的就叫做循环不变量


在上面的算法代码中,循环体其实就是判断一下data[i]是否是target,如果是的话就return了,如果不是的话,本轮循环就结束了,就要进行下一轮循环。


3.2循环体维持循环不变量

✳️依靠循环体,维持了循环不变量:


public static <E> int search(E[] data, E target){

for(int i = 0; i < data.length; i ++)

 if(data[i].equals(target))

  return i;

return -1;

   }

1

2

3

4

5

6

1️⃣在上面的算法代码中,循环体在做的事情,其实就是在维持这个循环不变量——经过了这轮循环体之后,要么整个循环结束了,完成了return i;要么循环继续,在下一轮循环中依旧满足[0,i-1]这个区间中没有找到目标。


2️⃣在循环结束的时候,如果i = data.length,对应到这个循环不变量中,就是data在[0,data.length-1]即在整个data中都没有找到目标,那么就return -1代表没有找到,如果找到了的话当然就是直接return i了


三、复杂度分析

1. 为何需要复杂度分析?

✅之所以要对算法做复杂度分析,是因为需要表示算法的性能


对于做同样的一个任务,我们会有不同的算法能够完成这个任务,对于不同的算法来说,他们的时间性能有差异,可以具体的用一个或者是一组测试用例对不同的算法都运行一下,实际的去比较一下他们的性能差异,但是这样的比较结果是有局限性的,因为无法保证运行不同的算法的这个计算机性能是完全一致的,甚至很难保证系统当时的状态都是完全一致的。而且这样做我们必须先把这个算法实际的实现出来才能看到它的性能。


❓很多时候有一个算法思想后,我们可不可能通过这个算法的思想就大致评估出算法的性能是优是劣、能否能够满足真正的业务需求再来决定是否要去实现它。


❗这些原因使得我们需要有一套工具能够非常抽象的从数学的层面就去判断一个算法它的性能是怎样的。


✔️为了解决上述需求,就产生了复杂度分析


2.复杂度分析如何表示算法性能?

依旧以前面线性查找的代码为例,分析它的复杂度


public static <E> int search(E[] data, E target){

for(int i = 0; i < data.length; i ++)

 if(data[i].equals(target))

  return i;

return -1;

   }

1

2

3

4

5

6

☑️**逻辑:**从头到尾遍历一次data这个数组,如果发现是我们要找到目标元素的话,返回对应的索引,否则的话整个for循环都走一遍,没有找到目标元素直接return -1


☑️时间:这个算法它执行的时间的多少,其实是和target出现在data中的位置相关的——target就在data[0]的位置,那么for循环执行一趟,算法直接结束,return i即可;如果target在data的末尾或者是target没有在data中,那么这个算法整个for循环从头到尾就都要执行一遍


☑️根据我们的测试用例的不同,算法实际执行的时间是不一样的


✔️对于复杂度分析来说,表示的是我们算法运行的上界,预估算法的性能,即不能比这更差了,通常是看最差的情况的


3.复杂度分析的运用

✳️对于前面线性查找的算法,算法运行的时间的大小,是和data数组中元素个数相关的


☑️通常我们对一个算法所作用的数据的大小叫做数据的规模,使用字母n表示——在线性查找法中,数据规模n就是数组data的大小,即data.length


☑️我们无需仔细的分析一轮循环对n个元素操作需要多少指令,我们只需要知道整个算法的性能和data数组的大小即数据规模n成一个正比的关系,把它记作大O,n级别的算法即O(n)


☑️在算法复杂度分析的世界中,常数是不重要的。


✴️复杂度描述的是随着这个数据规模n的增大算法性能变化的趋势


相关文章
|
8天前
|
运维 监控 JavaScript
基于 Node.js 图结构的局域网设备拓扑分析算法在局域网内监控软件中的应用研究
本文探讨图结构在局域网监控系统中的应用,通过Node.js实现设备拓扑建模、路径分析与故障定位,提升网络可视化、可追溯性与运维效率,结合模拟实验验证其高效性与准确性。
66 3
|
4月前
|
机器学习/深度学习 边缘计算 算法
NOMA和OFDMA优化算法分析
NOMA和OFDMA优化算法分析
244 127
|
6月前
|
数据采集 机器学习/深度学习 算法
别急着上算法,咱先把数据整明白:大数据分析的5个基本步骤,你都搞对了吗?
别急着上算法,咱先把数据整明白:大数据分析的5个基本步骤,你都搞对了吗?
254 4
|
3月前
|
存储 监控 安全
企业上网监控系统中红黑树数据结构的 Python 算法实现与应用研究
企业上网监控系统需高效处理海量数据,传统数据结构存在性能瓶颈。红黑树通过自平衡机制,确保查找、插入、删除操作的时间复杂度稳定在 O(log n),适用于网络记录存储、设备信息维护及安全事件排序等场景。本文分析红黑树的理论基础、应用场景及 Python 实现,并探讨其在企业监控系统中的实践价值,提升系统性能与稳定性。
76 1
|
3月前
|
人工智能 自然语言处理 算法
2025 年 7 月境内深度合成服务算法备案情况分析报告
2025年7月,中央网信办发布第十二批深度合成算法备案信息,全国389款产品通过备案,服务提供者占比超七成。截至7月14日,全国累计备案达3834款,覆盖文本、图像、音视频等多模态场景,广泛应用于生活服务、医疗、金融等领域。广东以135款居首,数字人、AI客服等C端应用主导,民营企业成主力,国企聚焦公共服务。随着AI政策推动,备案已成为AI产品合规上线关键环节。
|
3月前
|
存储 监控 算法
基于跳表数据结构的企业局域网监控异常连接实时检测 C++ 算法研究
跳表(Skip List)是一种基于概率的数据结构,适用于企业局域网监控中海量连接记录的高效处理。其通过多层索引机制实现快速查找、插入和删除操作,时间复杂度为 $O(\log n)$,优于链表和平衡树。跳表在异常连接识别、黑名单管理和历史记录溯源等场景中表现出色,具备实现简单、支持范围查询等优势,是企业网络监控中动态数据管理的理想选择。
90 0
|
6月前
|
存储 监控 算法
员工行为监控软件中的 Go 语言哈希表算法:理论、实现与分析
当代企业管理体系中,员工行为监控软件已逐步成为维护企业信息安全、提升工作效能的关键工具。这类软件能够实时记录员工操作行为,为企业管理者提供数据驱动的决策依据。其核心支撑技术在于数据结构与算法的精妙运用。本文聚焦于 Go 语言中的哈希表算法,深入探究其在员工行为监控软件中的应用逻辑与实现机制。
148 14
|
7月前
|
自然语言处理 算法 安全
境内深度合成服务算法备案通过名单分析报告
本报告基于《境内深度合成服务算法备案通过名单》,分析了2023年6月至2025年3月公布的10批备案数据,涵盖属地分布、行业应用及产品形式等多个维度。报告显示,深度合成算法主要集中于经济发达地区,如北京、广东、上海等地,涉及教育、医疗、金融、娱乐等多行业。未来趋势显示技术将向多模态融合、行业定制化和安全合规方向发展。建议企业加强技术研发、拓展应用场景、关注政策动态,以在深度合成领域抢占先机。此分析旨在为企业提供参考,助力把握技术发展机遇。
境内深度合成服务算法备案通过名单分析报告
|
7月前
|
供应链 算法 搜索推荐
从公布的前十一批其他算法备案通过名单分析
2025年3月12日,国家网信办发布算法备案信息,深度合成算法通过395款,其他算法45款。前10次备案中,深度合成算法累计3234款,其他类别647款。个性化推送类占比49%,涵盖电商、资讯、视频推荐;检索过滤类占31.53%,用于搜索优化和内容安全;调度决策类占9.12%,集中在物流配送等;排序精选类占8.81%,生成合成类占1.55%。应用领域包括电商、社交媒体、物流、金融、医疗等,互联网科技企业主导,技术向垂直行业渗透,内容安全和多模态技术成新增长点。未来大模型检索和多模态生成或成重点。
从公布的前十一批其他算法备案通过名单分析
|
7月前
|
算法 Java
算法系列之数据结构-Huffman树
Huffman树(哈夫曼树)又称最优二叉树,是一种带权路径长度最短的二叉树,常用于信息传输、数据压缩等方面。它的构造基于字符出现的频率,通过将频率较低的字符组合在一起,最终形成一棵树。在Huffman树中,每个叶节点代表一个字符,而每个字符的编码则是从根节点到叶节点的路径所对应的二进制序列。
159 3
 算法系列之数据结构-Huffman树

热门文章

最新文章