二分查找算法

  二分查找(也叫折半查找)是在有序列表中频繁使用到的查找算法,复杂度为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 }
复制代码

 

posted @   爱喝可乐的咖啡  阅读(222)  评论(0编辑  收藏  举报
编辑推荐:
· 记一次.NET内存居高不下排查解决与启示
· 探究高空视频全景AR技术的实现原理
· 理解Rust引用及其生命周期标识(上)
· 浏览器原生「磁吸」效果!Anchor Positioning 锚点定位神器解析
· 没有源码,如何修改代码逻辑?
阅读排行:
· 分享4款.NET开源、免费、实用的商城系统
· 全程不用写代码,我用AI程序员写了一个飞机大战
· MongoDB 8.0这个新功能碉堡了,比商业数据库还牛
· 白话解读 Dapr 1.15:你的「微服务管家」又秀新绝活了
· 上周热点回顾(2.24-3.2)
点击右上角即可分享
微信分享提示