用SCL语言编写的二分查找算法,查找数组中的数据

百科   2024-09-07 20:55   山东  


集合中查找某个元素并获取元素位置的方法大家可能并不陌生,简单暴力的做法就是用for遍历一遍。不过这样做查找较大集合中元素会耗费时间,影响效率。对于PLC这种单线程的系统来说会大大影响扫描周期,是不能容忍的。


那么有没有方法提高查找效率呢,这就不得不说二分查找。因为高效的查找效率,二分查找算法总能排进计算机十大经典算法


一、二分查找算法原理

一个升序数组分成两半,比较中间值与目标值的大小。如果目标值等于中间值,则查找成功并返回中间值的索引。如果目标值小于中间值,则在数组的左半部分继续查找;反之,则在右半部分继续查找。不断迭代,直到找到目标值或确定目标值不存在于数组中。


二分查找有一个前提条件:数组一定是有序的,即数组中元素按升序或降序排列。

二、二分查找与遍历查找的比较

从二分查找算法原理不难看出二分查找每次迭代都会排除原查找集合的一半,查找效率在迭代中是成指数增长的,对于二分查找算法时间复杂度O=Log n (n=数组中元素个数)。而对于遍历查找,时间复杂度O=n(n=数组中元素个数)。大家可自行计算对有1000个元素的数组进行元素查找两种算法的时间复杂度进行对比,差距是巨大的。这也就是说越庞大的数组二分查找效率优势越明显。


但二分查找也有弱点,就是数组一定要有序,一旦数组无序将会导致严重的错查、漏查。而遍历查找对元素顺序不敏感。


三、PLC程序实现二分查找

1、子程序形参列表和说明:


2、程序源码


第一个Region用于计算不定长数组长度和初始化查找边界。


第二个Region用于数组校验和具体算法实现。


四、程序测试

      将子程序在主程序中调用一下后仿真,输入查找目标,发现成功输出了目标索引。


当输入一个数组中没有的元素时,发现索引返回了特定值,并且msg中给与了正确的提示。


当我们输入的两次数组不一致时,msg也给了正确的提示。

五、二分查找扩展

二分查找可以查找有序数组中的相同元素,做法是简单的变换一下源码同时找到有序数组中相同元素最右侧的索引和最左侧索引。源码和以上源码是“瓢”和“葫芦”的关系,笔者这里就不分开写了。

加入知识星球智能制造与自动化,加入会员可下载此公众号发布文章中的相关资料(行业报告、MES、数字化技术方案、自动化教程、自动化行业标准化资料VASS\SICAR\戴姆勒等、C#上位机开发、node-red开发、人工智能教程等)。

会员下载区

今天的文章,如果你感觉有价值,请记得一键三连:点赞加关注,留言,转发朋友圈,分享收藏,点击在看之后,一定记着加我个人微信:ZIDHXB。

往期精彩回顾




汽车行业Sicar控制标准资料有偿获取
博途PLC与FactoryIO联合仿真教程限时分享
PLC程序动态加密—分级催款可远程授权程序与授权软件分享
SIEMENS/西门子杯,六部十层电梯程序分享
FactoryIO与博途联合三色物料气缸分拣站程序分享
多台排水泵按累计运行时间切换和先启先停切换多模式控制PLC程序分享
倍福PLC视频教程及资料免费分享(36G)
三菱PLC编写的贪吃蛇与俄罗斯方块程序分享
库卡EthernetKRL备选软件包分享(版本V3.1.3)
精美博途Wincc界面程序模板分享
TIA_Portal_v18虚拟机分享
西门子博途V19全家桶与最新授权下载
大众VASS05标准Step7v5.5软件虚拟机分享
TIA_Portal_v19虚拟机分享
西门子SCL编程实例—扫雷游戏分享
西门子TIA博途软件入门到精通教程免费分享
西门子S7-1500博途PLC(基础+高级)视频教程分享
西门子TIA博途-SCL高级编程多套视频资料免费分享-限时删除
西门子TIA博途高级语言SCL视频资料分享
三菱FX3U系列plc精讲视频分享(40讲+240讲) 49GB
西门子smart200视频教程分享
两套西门子WinCC视频教程分享(9.5G)
PLC、触摸屏工控小游戏样例合集分享
EPLAN电气设计制图视频教程分享-限时删除
都有哪些好用电工仿真软件?学习电路图变得如此简
67本自动化书籍免费领取啦!!!
最新西门子授权工具EKB2022版分享
立体仓库穿梭车程序分享
威纶触摸屏视频教程(66讲)分享
博途TIA V16-V17全套软件与组件分享
标准化编程之-博途TIA程序设计编程规范
西门子SCL编程练习:排水泵根据运行时间先起先停控制
如何使用C#编写程序读写西门子PLC?
VASS标准—PLC安全程序架构讲解
VASS05标准—KUKA机器人培训课件
大众VASS_05标准——PLC程序架构
大众VASS05生画面遇到的问题总结
SEW_MOVIPRO变频器在VASS05标准中的应用
SEW_MOVIFIT变频器在VASS05标准中的应用
KUKA机器人高级编程(下)第3-4章(计时器\运动编程)
西门子博途SCL案例_仓储系统出料优先级控制程序实战练习
西门子TIA博途SCL高级教程—伺服V90速度控制
西门子TIA博途SCL高级教程—伺服V90定位控制
西门子TIA博途SCL高级视频教程—模拟量在工程中的应用
博途TIA Portal——SCL间接寻址PEEK和POKE指令的使用案例
西门子SCL高级语言教程—冒泡排序和选择排序
西门子SCL编程实例—字与位的转换Word_To_Bit
西门子博途WINCC脚本VBS教程4_脚本操作画面内对象的属性
如何使用C#编写程序读写西门子PLC?
C#上位机通过TCP/IP协议和KUKA机器人通讯
不外传的28条PLC编程规范及建议,赶紧收藏
win10家庭版安装西门子博途软件时提示“管理员已阻止你运行此应用”解决方法
西门子SCL编程-数据堆栈存储与操作在项目中的使用
博途实现程序动态加密—分级催款密钥授权管理系统程序实现
分享几个PROFINET网络故障诊断与分析案例
工控的面向对象编程
SiCar自动化标准平台架构
特斯拉EPLAN 电气图纸和结构标准
SICAR标准-VALVE_1_TO_8_3POS_FB夹具控制功能块
西门子PLC信号分析软件Winplc Analyzer 使用方法
PROFINET设备的GSD文件及其描述语言GSDML
大众标准VASS06软件环境设置
ABB机器人编程与应用中级篇
PLC编程算法—FIFO堆栈程序的实现
大众VASS06 项目库标准程序结构.
C#利用S7netplus读写西门子PLC数据
吉利KUKA_KRC4系列机器人现场应用规范和技术要求
TESLA特斯拉—PLC 逻辑编程规范
TESLA特斯拉—SCADA 设计规范
多台排水泵按累计运行时间切换和先启先停切换多模式控制PLC程序分享
西门子S7-200SMART编码器线速度测量算法
西门子S7-200SMART一阶RC低通滤波算法原理与实现
博途S7-1500SCL与FactoryIO仿真实现一阶RC低通滤波器皮带机速度平滑控制
Node-Red与ModbusTCP设备通信——写数据
Node-Red与ModbusTCP设备通信——读数据
大众汽车PLC-VASS05标准视频教程
你知道制造业10大系统集成:SCADA、MES、PLM、ERP、SCM、WMS、APS、QMS、CRM、EAM的关系吗?
西门子S7-300 SCL编程实现数组队列搜索、插入、删除、改动功能


智能制造与自动化
每天学习一点点,时间会给你一个不可思议的礼物。定期分享智能制造与自动化知识点,分享比收获更让人幸福。 智能制造、自动化、数字化、机器人、工业互联网 PLC\x5cMES\x5cSCADA\x5cEPLAN\x5c 西门子\x5c三菱\x5c施耐德\x5cKUKA\x5c
 最新文章