Gavin.han

致力于移动开发 技术改变生活
随笔 - 133, 文章 - 0, 评论 - 46, 阅读 - 42万

导航

< 2025年3月 >
23 24 25 26 27 28 1
2 3 4 5 6 7 8
9 10 11 12 13 14 15
16 17 18 19 20 21 22
23 24 25 26 27 28 29
30 31 1 2 3 4 5

查找算法 分享2:折半(二分)查找

Posted on   gavin.han  阅读(993)  评论(0编辑  收藏  举报

折半查找秘诀:折半,匹配中间值,折半,匹配中间值,折半,匹配中间值....  ,等于中间值,跳出,找到数据。

 

 大致步骤:

设3个变量low,mid,high,分别保存数组元素的开始、中间和末尾的序号。 假定有10个元素,开始时让low=0,high=9,mid = (low+high)/2=4.

1. 如果序号为mid的数组元素的值与x(要找的数)相等,表示查找到了数据,返回该数据的序号mid.

2.如果x<a[mid],表示要查找的数据x位于low与mid-1之间,就不需要再去查找mid与high序号之间的元素了。因此,将high变量的值改为mid-1,重新查找low与mid-1(即high变量的新值)之间的数据。 

3.如果x>a[mid],表示要查找的数据x位于mid+1与high序号之间,就不需要再去查找low与mid序号之间的元素了。因此,将low变量的值改为mid+1,重新查找mid+1(即low变量的新值)与high之间的数据。

4.逐步循环,如果到low>high时,还未周到目标数据x,则表示数组中没有这个数据。 

复制代码
#import <Foundation/Foundation.h>

int main(int argc, const char * argv[])
{

    @autoreleasepool {
        
        int a[10];
        int x, z;
        
        printf("请输入10个有序数字:\n");
        
        for (int i = 0; i < 10; i++) {
            scanf("%d", &a[i]);
        }
        
        printf("请输入要查找的数:\n");
        scanf("%d", &x);
        
        z = binarySearch(a, 10, x);
        
        if (z) {
            printf("您要查找的%d,在数组的第%d个元素", x, z);
        }
        else{
        
            printf("您查找的数找不到");
        }
    }
    return 0;
}

int binarySearch(int a[], int n, int x){

    int low, mid, high;
    low = 0;
    high = n - 1;
    while (low <= high) {
        mid = low + high;
        if (x == mid) {
            return mid + 1;
        }else if (x < mid){
        
            high = mid - 1;
        }
        else{
        
            low = mid + 1;
        }
    }
    return 0;
复制代码

折半查找是一种高效的查找算法,它可以明显地减少比较次数,提高查找效率。但是折半查找的先决条件是查找表中的数据元素必须是有序的。


编辑推荐:
· 如何编写易于单元测试的代码
· 10年+ .NET Coder 心语,封装的思维:从隐藏、稳定开始理解其本质意义
· .NET Core 中如何实现缓存的预热?
· 从 HTTP 原因短语缺失研究 HTTP/2 和 HTTP/3 的设计差异
· AI与.NET技术实操系列:向量存储与相似性搜索在 .NET 中的实现
阅读排行:
· 10年+ .NET Coder 心语 ── 封装的思维:从隐藏、稳定开始理解其本质意义
· 地球OL攻略 —— 某应届生求职总结
· 提示词工程——AI应用必不可少的技术
· Open-Sora 2.0 重磅开源!
· 周边上新:园子的第一款马克杯温暖上架
点击右上角即可分享
微信分享提示