博客
关于我
Objective-C实现binary search二分查找算法(附完整源码)
阅读量:795 次
发布时间:2023-02-17

本文共 1805 字,大约阅读时间需要 6 分钟。

Objective-C????????

??????????????????????????????????Objective-C???????????????????

????????

  • ????????????????????????????????????????

  • ??????????????????????????(d + 1)/2????????????????

  • ???????

    • ???????????????????
    • ??????????????????????-1??????????
    • ??????????????????????+1??????????
  • ?????????????????????????????????????-1?

  • ????

    #import 
    @interface BinarySearch : NSObject- (NSInteger)binarySearch:(NSArray *)array withTarget:(id)target;@end@implementation BinarySearch- (NSInteger)binarySearch:(NSArray *)array withTarget:(id)target { if (array == nil || [array count] == 0) { return -1; } NSInteger left = 0; NSInteger right = [array count] - 1; NSInteger middle; while (left <= right) { middle = (left + right) / 2; if ([array middleEquals:target]) { return middle; } else if ([array[middle] < target]) { left = middle + 1; } else { right = middle - 1; } } return -1;}@end

    ?????

    int main(int argc, const char *argv) {    NSAutoreleasePool *pool = [[NSAutoreleasePool alloc] init];        // ????????    NSArray *numbers = @[        @1, @2, @3, @4, @5, @6, @7,        @8, @9, @10    ];        // ??????    NSInteger result = [[BinarySearch alloc] binarySearch:numbers withTarget:@5];        // ????    printf("?????\n");    if (result != -1) {        printf("??? %ld ??????? %ld\n", 5, result);    } else {        printf("??? %ld ?????\n", 5);    }        return 0;}

    ????

    • ????????????NSObject??BinarySearch????????????
    • ???????binarySearch:withTarget:??????????????????????????-1??????
    • ????????????????????????-1?
    • ????????????????????????
    • ???????????????????????????????
    • ????????????????????????????-1?
    • ????????????????????????????????

    ??????????????????????????????Objective-C?????

    转载地址:http://odnfk.baihongyu.com/

    你可能感兴趣的文章
    Node-RED中使用Notification元件显示警告讯息框(温度过高提示)
    查看>>
    Node-RED中实现HTML表单提交和获取提交的内容
    查看>>
    Node.js 函数是什么样的?
    查看>>
    Node.js 实现类似于.php,.jsp的服务器页面技术,自动路由
    查看>>
    node.js 怎么新建一个站点端口
    查看>>
    Node.js 文件系统的各种用法和常见场景
    查看>>
    node.js 配置首页打开页面
    查看>>
    node.js+react写的一个登录注册 demo测试
    查看>>
    Node.js中环境变量process.env详解
    查看>>
    Node.js安装与配置指南:轻松启航您的JavaScript服务器之旅
    查看>>
    Node.js的循环与异步问题
    查看>>
    Nodejs express 获取url参数,post参数的三种方式
    查看>>
    nodejs libararies
    查看>>
    nodejs npm常用命令
    查看>>
    nodejs 运行CMD命令
    查看>>
    nodejs-mime类型
    查看>>
    nodejs中Express 路由统一设置缓存的小技巧
    查看>>
    nodejs包管理工具对比:npm、Yarn、cnpm、npx
    查看>>
    NodeJs单元测试之 API性能测试
    查看>>
    nodejs图片转换字节保存
    查看>>