二分查找算法
二分查找(也叫折半查找)是在有序列表中频繁使用到的查找算法,复杂度为O(logn)。
简单易懂的二分算法,用一个while循环解决:
1 int bin_search(int m[],int len,int goal) 2 { 3 int left=0,right=len-1; 4 int mid; 5 while(left<=right) 6 { 7 mid=(left+right)/2; 8 if(m[mid]==goal) 9 return mid; 10 else if(goal<m[mid]) 11 right=mid-1; 12 else if(goal>m[mid]) 13 left=mid+1; 14 } 15 return -666; //查找失败 16 }
下面是用递归实现的二分算法,虽然在执行效率上会慢那么一点,但更好理解记忆。
1 int binary_search(int m[],int left,int right,int goal) 2 { 3 if(left<=right) 4 { 5 int mid=(left+right)/2; 6 if(goal==m[mid]) 7 return mid; 8 else if(goal<m[mid]) 9 return binary_search(m,left,mid-1,goal); 10 else if(goal>m[mid]) 11 return binary_search(m,mid+1,right,goal); 12 } 13 else 14 return -666; 15 }
【推荐】国内首个AI IDE,深度理解中文开发场景,立即下载体验Trae
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· 记一次.NET内存居高不下排查解决与启示
· 探究高空视频全景AR技术的实现原理
· 理解Rust引用及其生命周期标识(上)
· 浏览器原生「磁吸」效果!Anchor Positioning 锚点定位神器解析
· 没有源码,如何修改代码逻辑?
· 分享4款.NET开源、免费、实用的商城系统
· 全程不用写代码,我用AI程序员写了一个飞机大战
· MongoDB 8.0这个新功能碉堡了,比商业数据库还牛
· 白话解读 Dapr 1.15:你的「微服务管家」又秀新绝活了
· 上周热点回顾(2.24-3.2)