博客
关于我
写代码可以在整型有序数组中查找想要的数字, 找到了返回下标,找不到返回-1.(折半查找)
阅读量:231 次
发布时间:2019-03-01

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

写代码实现整型有序数组的查找功能是一个非常常见的编程任务。要在数组中快速找到指定数字的位置,可以使用二分查找算法。这个方法不仅效率高,而且易于实现。

二分查找的核心思想是通过不断缩小查找范围来确定目标数字的位置。具体来说,算法会在数组中选取中间位置的元素,然后根据它与目标数字的大小关系决定下一步的查找方向。若目标数字比中间元素大,则只需在右边继续查找;反之,则在左边查找。如果在某一步中找到目标数字,则返回其位置;如果遍历完整个数组仍未找到目标,则返回-1。

以下是实现二分查找的代码示例:

#include 
#include
int binarysearch(int arr[], int size, int tofind) { int left = 0; int right = size - 1; while (left <= right) { int mid = (left + right) / 2; if (tofind > arr[mid]) { left = mid + 1; } else if (tofind < arr[mid]) { right = mid - 1; } else { return mid; } } return -1;}int main() { int arr[] = {0, 1, 2, 3, 4, 5, 6, 7}; int size = sizeof(arr) / sizeof(arr[0]); int num = binarysearch(arr, size, 8); if (num == -1) { printf("找不到!\n"); } else { printf("查找元素的下标是:%d\n", num); } system("pause"); return 0;}

以上代码实现了一个简单的二分查找功能。通过不断缩小查找范围,算法在O(log n)的时间复杂度内完成任务,适用于有序数组中快速查找特定数字的场景。

在实际应用中,可以根据需要对数组进行排序处理后再调用二分查找函数。该算法特别适用于大型有序数组的快速查找,能够有效提高程序运行效率。

如果需要更高级的功能扩展,可以考虑增加查找插入位置的功能,或者实现有序插入的逻辑,使得二分查找的适用范围更加广泛。

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

你可能感兴趣的文章
Neo4j(2):环境搭建
查看>>
Neo私链
查看>>
nessus快速安装使用指南(非常详细)零基础入门到精通,收藏这一篇就够了
查看>>
Nessus漏洞扫描教程之配置Nessus
查看>>
Nest.js 6.0.0 正式版发布,基于 TypeScript 的 Node.js 框架
查看>>
NetApp凭借领先的混合云数据与服务把握数字化转型机遇
查看>>
NetBeans IDE8.0需要JDK1.7及以上版本
查看>>
netcat的端口转发功能的实现
查看>>
netfilter应用场景
查看>>
netlink2.6.32内核实现源码
查看>>
Netpas:不一样的SD-WAN+ 保障网络通讯品质
查看>>
NetScaler的常用配置
查看>>
netsh advfirewall
查看>>
NETSH WINSOCK RESET这条命令的含义和作用?
查看>>
Netty WebSocket客户端
查看>>
netty 主要组件+黏包半包+rpc框架+源码透析
查看>>
Netty 异步任务调度与异步线程池
查看>>
Netty中集成Protobuf实现Java对象数据传递
查看>>
Netty事件注册机制深入解析
查看>>
Netty原理分析及实战(四)-客户端与服务端双向通信
查看>>