博客
关于我
写代码可以在整型有序数组中查找想要的数字, 找到了返回下标,找不到返回-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/

你可能感兴趣的文章
No qualifying bean of type XXX found for dependency XXX.
查看>>
No resource identifier found for attribute 'srcCompat' in package的解决办法
查看>>
no session found for current thread
查看>>
No toolchains found in the NDK toolchains folder for ABI with prefix: mips64el-linux-android
查看>>
NO.23 ZenTaoPHP目录结构
查看>>
NO32 网络层次及OSI7层模型--TCP三次握手四次断开--子网划分
查看>>
NoClassDefFoundError: org/springframework/boot/context/properties/ConfigurationBeanFactoryMetadata
查看>>
Node JS: < 一> 初识Node JS
查看>>
Node-RED中使用JSON数据建立web网站
查看>>
Node-RED中使用json节点解析JSON数据
查看>>
Node-RED中使用node-random节点来实现随机数在折线图中显示
查看>>
Node-RED中使用node-red-browser-utils节点实现选择Windows操作系统中的文件并实现图片预览
查看>>
Node-RED中使用Notification元件显示警告讯息框(温度过高提示)
查看>>
Node-RED中实现HTML表单提交和获取提交的内容
查看>>
Node.js 函数是什么样的?
查看>>
Node.js 历史
查看>>
Node.js 在个推的微服务实践:基于容器的一站式命令行工具链
查看>>
Node.js 实现类似于.php,.jsp的服务器页面技术,自动路由
查看>>
node.js 怎么新建一个站点端口
查看>>
Node.js 文件系统的各种用法和常见场景
查看>>