0

0

C++数组查找元素 线性与二分查找实现

P粉602998670

P粉602998670

发布时间:2025-08-22 13:14:01

|

730人浏览过

|

来源于php中文网

原创

线性查找适用于无序数组,时间复杂度O(n);二分查找效率高,时间复杂度O(log n),但要求数组有序。

c++数组查找元素 线性与二分查找实现

在C++中查找数组中的元素,最常用的方法是线性查找和二分查找。它们各有适用场景:线性查找适用于无序数组,时间复杂度为O(n);二分查找效率更高,时间复杂度为O(log n),但要求数组必须有序。

线性查找实现

线性查找从数组第一个元素开始,逐个比较,直到找到目标值或遍历完整个数组。

实现方式简单,不需要数组有序。

代码示例:

#include 
using namespace std;

int linearSearch(int arr[], int size, int target) { for (int i = 0; i < size; ++i) { if (arr[i] == target) { return i; // 返回找到的索引 } } return -1; // 未找到返回-1 }

int main() { int arr[] = {5, 3, 9, 1, 7}; int size = sizeof(arr) / sizeof(arr[0]); int target = 9; int result = linearSearch(arr, size, target);

if (result != -1) {
    cout zuojiankuohaophpcnzuojiankuohaophpcn "元素 " zuojiankuohaophpcnzuojiankuohaophpcn target zuojiankuohaophpcnzuojiankuohaophpcn " 在索引 " zuojiankuohaophpcnzuojiankuohaophpcn result zuojiankuohaophpcnzuojiankuohaophpcn " 处找到。\n";
} else {
    cout zuojiankuohaophpcnzuojiankuohaophpcn "元素 " zuojiankuohaophpcnzuojiankuohaophpcn target zuojiankuohaophpcnzuojiankuohaophpcn " 未找到。\n";
}

return 0;

}

立即学习C++免费学习笔记(深入)”;

超级简历WonderCV
超级简历WonderCV

免费求职简历模版下载制作,应届生职场人必备简历制作神器

下载

二分查找实现

二分查找每次将查找区间缩小一半,前提是数组必须按升序或降序排列

查找过程:比较中间元素与目标值,根据大小关系决定向左或向右继续查找。

代码示例(迭代方式):

#include 
using namespace std;

int binarySearch(int arr[], int size, int target) { int left = 0; int right = size - 1;

while (left <= right) {
    int mid = left + (right - left) / 2; // 防止溢出

    if (arr[mid] == target) {
        return mid;
    } else if (arr[mid] < target) {
        left = mid + 1;
    } else {
        right = mid - 1;
    }
}
return -1;

}

立即学习C++免费学习笔记(深入)”;

int main() { int arr[] = {1, 3, 5, 7, 9}; // 必须有序 int size = sizeof(arr) / sizeof(arr[0]); int target = 7; int result = binarySearch(arr, size, target);

if (result != -1) {
    cout zuojiankuohaophpcnzuojiankuohaophpcn "元素 " zuojiankuohaophpcnzuojiankuohaophpcn target zuojiankuohaophpcnzuojiankuohaophpcn " 在索引 " zuojiankuohaophpcnzuojiankuohaophpcn result zuojiankuohaophpcnzuojiankuohaophpcn " 处找到。\n";
} else {
    cout zuojiankuohaophpcnzuojiankuohaophpcn "元素 " zuojiankuohaophpcnzuojiankuohaophpcn target zuojiankuohaophpcnzuojiankuohaophpcn " 未找到。\n";
}

return 0;

}

立即学习C++免费学习笔记(深入)”;

递归方式实现二分查找

二分查找也可以用递归方式实现,逻辑清晰,便于理解。

int binarySearchRecursive(int arr[], int left, int right, int target) {
    if (left > right) {
        return -1;
    }
int mid = left + (right - left) / 2;

if (arr[mid] == target) {
    return mid;
} else if (arr[mid] < target) {
    return binarySearchRecursive(arr, mid + 1, right, target);
} else {
    return binarySearchRecursive(arr, left, mid - 1, target);
}

}

立即学习C++免费学习笔记(深入)”;

调用方式:binarySearchRecursive(arr, 0, size - 1, target);

基本上就这些。线性查找简单通用,二分查找高效但依赖有序。根据实际数据情况选择合适方法。

相关专题

更多
string转int
string转int

在编程中,我们经常会遇到需要将字符串(str)转换为整数(int)的情况。这可能是因为我们需要对字符串进行数值计算,或者需要将用户输入的字符串转换为整数进行处理。php中文网给大家带来了相关的教程以及文章,欢迎大家前来学习阅读。

312

2023.08.02

int占多少字节
int占多少字节

int占4个字节,意味着一个int变量可以存储范围在-2,147,483,648到2,147,483,647之间的整数值,在某些情况下也可能是2个字节或8个字节,int是一种常用的数据类型,用于表示整数,需要根据具体情况选择合适的数据类型,以确保程序的正确性和性能。本专题为大家提供相关的文章、下载、课程内容,供大家免费下载体验。

522

2024.08.29

c++怎么把double转成int
c++怎么把double转成int

本专题整合了 c++ double相关教程,阅读专题下面的文章了解更多详细内容。

49

2025.08.29

C++中int的含义
C++中int的含义

本专题整合了C++中int相关内容,阅读专题下面的文章了解更多详细内容。

190

2025.08.29

php源码安装教程大全
php源码安装教程大全

本专题整合了php源码安装教程,阅读专题下面的文章了解更多详细内容。

7

2025.12.31

php网站源码教程大全
php网站源码教程大全

本专题整合了php网站源码相关教程,阅读专题下面的文章了解更多详细内容。

4

2025.12.31

视频文件格式
视频文件格式

本专题整合了视频文件格式相关内容,阅读专题下面的文章了解更多详细内容。

7

2025.12.31

不受国内限制的浏览器大全
不受国内限制的浏览器大全

想找真正自由、无限制的上网体验?本合集精选2025年最开放、隐私强、访问无阻的浏览器App,涵盖Tor、Brave、Via、X浏览器、Mullvad等高自由度工具。支持自定义搜索引擎、广告拦截、隐身模式及全球网站无障碍访问,部分更具备防追踪、去谷歌化、双内核切换等高级功能。无论日常浏览、隐私保护还是突破地域限制,总有一款适合你!

7

2025.12.31

出现404解决方法大全
出现404解决方法大全

本专题整合了404错误解决方法大全,阅读专题下面的文章了解更多详细内容。

42

2025.12.31

热门下载

更多
网站特效
/
网站源码
/
网站素材
/
前端模板

精品课程

更多
相关推荐
/
热门推荐
/
最新课程
C++教程
C++教程

共115课时 | 10.7万人学习

MySQL 初学入门(mosh老师)
MySQL 初学入门(mosh老师)

共3课时 | 0.3万人学习

手把手实现数据传输编码
手把手实现数据传输编码

共1课时 | 706人学习

关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送

Copyright 2014-2026 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号