当前位置: 首页 > news >正文

数据结构——二分查找法

二分查找法(Binary Search)是一种高效的查找算法,通常用于在已排序的数组或列表中查找特定的目标值。这个算法的基本思想是不断将查找范围缩小为原来的一半,直到找到目标值或确定目标值不存在。

二分查找是一种在每次比较之后将查找空间一分为二的算法。每次需要查找集合中的索引或元素时,都应该考虑二分查找。如果集合是无序的,我们可以总是在应用二分查找之前先对其进行排序。

二分查找一般由三个主要部分组成:
1.预处理一如果集合未排序,则进行排序.
2.二分查找一 使用循环或递归在每次比较后将查找空间划分为两半
3. 后处理在剩余空间中确定可行的候选者

1.二分查找函数 是二分查找的最基础和最基本的形式。这是一个标准的二分查找模板

int binarySearch(const std::vector<int>& arr, int target) {int left = 0;int right = arr.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; // 目标值不存在
}

2.二分查找函数 是二分查找的高级模板。它用于查找需要访问数组中当前索引及其直接右邻居索引的元素或条件。

int binarySearch(vector<int>& nums, int target) {if (nums.size() == 0)return -1;int left = 0, right = nums.size();while (left < right) {// Prevent (left + right) overflowint mid = left + (right - left) / 2;if (nums[mid] == target){ return mid;}else if (nums[mid] < target) { left = mid + 1; }else { right = mid; }}// Post-processing:// End Condition: left == rightif (left != nums.size() && nums[left] == target) return left;return -1;
}

3.二分查找函数 是二分查找的另一种独特形式。 它用于搜索需要访问当前索引及其在数组中的直接左右邻居索引的元素或条件。

int binarySearch3(vector<int>& nums, int target) {if (nums.size() == 0)return -1;int left = 0, right = nums.size() - 1;while (left + 1 < right) {// Prevent (left + right) overflowint mid = left + (right - left) / 2;if (nums[mid] == target) {return mid;}else if (nums[mid] < target){left = mid;}else{right = mid;}}// Post-processing:// End Condition: left + 1 == rightif (nums[left] == target)return left;if (nums[right] == target)return right;return -1;
}
http://www.lryc.cn/news/166964.html

相关文章:

  • 服务端渲染(SSR):提升Web应用性能和用户体验的关键技术
  • 如何工作和生活相平衡?
  • semaphere部署,配置ldap
  • Java 泛型 T,E,K,V,?
  • 软件测试技术之地图导航的测试用例
  • 【C++】常用集合算法
  • css flex:1;详解,配合demo效果解答
  • discuzQ安装
  • 深入解析NLP情感分析技术:从篇章到属性
  • JVM的双亲委派模型
  • js中如何判断一个变量是否为数字类型?
  • 使用阿里PAI DSW部署Stable Diffusion WebUI
  • redisson使用过程常见问题汇总
  • 代码随想录训练营 DP序列
  • Datastage部署与使用
  • 【实用工具】Centos 安装ARL灯塔
  • IP地址定位基础数据采集
  • leetcode做题笔记138. 复制带随机指针的链表
  • 分布式文件系统的新兴力量:揭秘Alluxio的元数据管理机制【文末送书】
  • ArcGIS标注的各种用法和示例
  • 修改ros中的控制器,便于仿真和驱动真实UR
  • 网络广播模块2*30W 智能4G广播终端开发模块
  • 优思学院|什么是精益项目管理?
  • 【Android取证篇】华为设备跳出“允许USB调试“界面方法的不同方法
  • 在VSCode中移除不必要的扩展
  • 算法刷题记录-树(LeetCode)
  • Linux中安装MySQL_图解_2023新
  • 生产设备上的静电该如何处理?
  • 山洪灾害预警方案(山洪预警解决方案的组成)
  • 数据库 MVCC 详解