二分查找
二分查找
二分查找(二分搜索)又称折半查找,它要求线性表是有序的,并且需要用一维数组进行存储。二分查找的基本思想如下:
假设L[low......high]为当前要查找的区间(假设是递增有序)。
(1)首先确定该区间的中间位置,mid=(low+high)/2;
(2)将待查找的key值与L[mid].key进行比较,如果相等,则查找结束;若不等,则在新的区间进行相同的操作,新的区间确定过程如下:
1)若key>L[mid].key,则key值只可能在mid的右边区间,则新的查找区间为L[mid+1,high];
2)若key<L[mid].key,则key值只可能在mid的左边区间,则新的查找区间为L[low,mid-1];
int BinarySearch(SeqList R,int low,int high,ElemType key) { int mid; while(low<=high) { mid=low+(high-low)>>1; //可以有效地避免溢出的情况 if(key==R[mid].key) return mid; if(key<R[mid].key) high=mid-1; else low=mid+1; } return -1; }
递归实现:
int BinarySearch(SeqList R,int low,int high,ElemType key) { if(low>high) return -1; int mid=low+(high-low)>>1; if(key==R[mid].key) return mid; else { if(key<R[mid].key) BinarySearch(R,low,mid-1,key); else BinarySearch(R,mid+1,high,key); } }
【推荐】国内首个AI IDE,深度理解中文开发场景,立即下载体验Trae
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· AI与.NET技术实操系列(二):开始使用ML.NET
· 记一次.NET内存居高不下排查解决与启示
· 探究高空视频全景AR技术的实现原理
· 理解Rust引用及其生命周期标识(上)
· 浏览器原生「磁吸」效果!Anchor Positioning 锚点定位神器解析
· DeepSeek 开源周回顾「GitHub 热点速览」
· 物流快递公司核心技术能力-地址解析分单基础技术分享
· .NET 10首个预览版发布:重大改进与新特性概览!
· AI与.NET技术实操系列(二):开始使用ML.NET
· 单线程的Redis速度为什么快?