技术文摘
C++ 与 Python 中二分查找的实现方法
C++ 与 Python 中二分查找的实现方法
在编程领域,二分查找是一种高效的查找算法,适用于已排序的数组或列表。下面分别介绍在 C++ 和 Python 中二分查找的实现方法。
在 C++ 中,二分查找通常通过循环来实现。以下是一个简单的示例代码:
#include <iostream>
int binarySearch(int arr[], int l, int r, int x) {
while (l <= r) {
int m = l + (r - l) / 2;
if (arr[m] == x)
return m;
if (arr[m] < x)
l = m + 1;
else
r = m - 1;
}
return -1;
}
int main() {
int arr[] = {2, 5, 8, 12, 16, 23, 38, 56, 72, 91};
int n = sizeof(arr) / sizeof(arr[0]);
int x = 23;
int result = binarySearch(arr, 0, n - 1, x);
if (result!= -1)
std::cout << "元素在数组中的索引为: " << result << std::endl;
else
std::cout << "数组中未找到该元素" << std::endl;
return 0;
}
在上述 C++ 代码中,binarySearch 函数接受一个已排序的整数数组 arr 、左右边界 l 和 r 以及要查找的目标值 x 。通过不断比较中间元素与目标值的大小,调整搜索范围,直到找到目标值或确定不存在。
而在 Python 中,二分查找可以通过递归或循环来实现。下面是一个使用循环的实现方式:
def binary_search(arr, x):
low = 0
high = len(arr) - 1
while low <= high:
mid = (low + high) // 2
if arr[mid] == x:
return mid
elif arr[mid] < x:
low = mid + 1
else:
high = mid - 1
return -1
arr = [2, 5, 8, 12, 16, 23, 38, 56, 72, 91]
x = 23
result = binary_search(arr, x)
if result!= -1:
print("元素在数组中的索引为:", result)
else:
print("数组中未找到该元素")
无论是 C++ 还是 Python,二分查找的核心思想都是通过不断缩小搜索范围,快速定位目标元素。这种算法的时间复杂度为 O(log n),相较于顺序查找的 O(n),在处理大规模数据时具有明显的优势。
掌握二分查找的实现方法,对于提高程序的效率和性能有着重要的意义。在实际应用中,根据具体的需求和语言特点,选择合适的实现方式。
TAGS: 编程语言对比 Python 二分查找 C++ 二分查找 二分查找实现
- Java11 至 17 新特性的诙谐速览
- 零起点学 Java 之变量与计算
- 这里涵盖您所需的 API 基础知识
- WebFlux 中的函数式编程运用
- Java 程序无源代码文件的修改之法
- 学习性能优化:怎样模拟各类故障场景
- 解决在渲染函数之外调用插槽的方法
- 深度解析 CSS 单位
- Packj 检测恶意或高风险开源软件包的方法
- 关于异地多活改造,我要与架构师一争高下
- Intersection Observer:跟踪元素可视的尝试
- C++之父对被建议弃用作出回应:部分高管热衷迷恋新事物
- 微服务中的授权认证:Identity Server 4
- C++ 标准模板库:C++ 进阶初学者教程
- 现代 Monorepo 工程技术选型的思考