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

驻马店北京网站建设江西省都昌县建设局网站

驻马店北京网站建设,江西省都昌县建设局网站,免费发布信息网站网址大全,wordpress声明插件文章目录 前言二分查找模板朴素模板左右查找模板 一、二分查找二、 在排序数组中查找元素的第一个和最后一个位置三、搜索插入位置四、x 的平方根五、山脉数组的峰顶索引六、寻找峰值七、寻找旋转排序数组中的最小值八、 点名总结 前言 二分查找是一种高效的查找算法&#xff…

文章目录

  • 前言
  • 二分查找模板
    • 朴素模板
    • 左右查找模板
  • 一、二分查找
  • 二、 在排序数组中查找元素的第一个和最后一个位置
  • 三、搜索插入位置
  • 四、x 的平方根
  • 五、山脉数组的峰顶索引
  • 六、寻找峰值
  • 七、寻找旋转排序数组中的最小值
  • 八、 点名
  • 总结


前言

二分查找是一种高效的查找算法,适用于有序数组。通过不断将查找范围缩小为一半,它在 O(log n) 时间内定位目标元素,大幅提高查找效率。

二分查找适用于可将数据划分为两块的情况,不一定非要排序。

在这里插入图片描述


二分查找模板

朴素模板

在这里插入图片描述


左右查找模板

在这里插入图片描述


一、二分查找

二分查找

在这里插入图片描述
在这里插入图片描述

class Solution {
public:int search(vector<int>& nums, int target) {int left = 0, right = nums.size() - 1;while (left <= right){int mid = left + (right - left) / 2;if(nums[mid] < target) left = mid + 1;else if(nums[mid] > target) right = mid - 1;else return mid;}return -1;}
};

二、 在排序数组中查找元素的第一个和最后一个位置

在排序数组中查找元素的第一个和最后一个位置

在这里插入图片描述

在这里插入图片描述

class Solution {
public:vector<int> searchRange(vector<int>& nums, int target) {if(nums.size() == 0) return {-1, -1};int begin = 0;int left = 0, right = nums.size() - 1;//1. 查找左边界while (left < right){int mid = left + (right - left) / 2;if (nums[mid] < target) left = mid + 1;else right = mid;}//判断值是否是我们要的targetbegin = left;if (nums[begin] != target){return {-1, -1};}//小优化,查右边left不用更新,right要更新right = nums.size() - 1;while (left < right){int mid = left + (right - left + 1) / 2;if (nums[mid] <= target) left = mid;else right = mid - 1; }return {begin, right};}
};

三、搜索插入位置

搜索插入位置

在这里插入图片描述

在这里插入图片描述

class Solution {
public:int searchInsert(vector<int>& nums, int target) {int left = 0, right = nums.size() - 1;while(left < right){int mid = left + (right - left) / 2;if (nums[mid] < target) left = mid + 1;else right = mid;}if(nums[left] < target) return left + 1;else return left;}
};

四、x 的平方根

x 的平方根

在这里插入图片描述

在这里插入图片描述

class Solution {
public:int mySqrt(int x) {if(x < 1) return 0;int left = 1, right = x;while (left < right){long long mid = left + (right - left + 1) / 2;if (mid * mid <= x) left = mid;else right = mid - 1;}return left;}
};

五、山脉数组的峰顶索引

山脉数组的峰顶索引
在这里插入图片描述

在这里插入图片描述

class Solution {
public:int peakIndexInMountainArray(vector<int>& arr) {int left = 1, right = arr.size() - 2;while(left < right){int mid = left + (right - left + 1) / 2;if(arr[mid] > arr[mid - 1]) left = mid;else right = mid - 1;}return right;}
};

六、寻找峰值

寻找峰值

在这里插入图片描述

在这里插入图片描述

class Solution {
public:int findPeakElement(vector<int>& nums) {int left = 0, right = nums.size() - 1;while (left < right){int mid = left + (right - left + 1) / 2;if (nums[mid] > nums[mid - 1]) left = mid;else right = mid - 1;}return right;}
};

七、寻找旋转排序数组中的最小值

寻找旋转排序数组中的最小值

在这里插入图片描述

class Solution {
public:int findMin(vector<int>& nums) {int left = 0, right = nums.size() - 1;int n = nums.size() - 1;while (left < right){int mid = left + (right -left) / 2;if (nums[mid] > nums[n]) left = mid + 1;else right = mid;}return nums[right];}
};

八、 点名

点名
在这里插入图片描述

在这里插入图片描述

class Solution {
public:int takeAttendance(vector<int>& records) {int left = 0, right = records.size() - 1;while(left < right){int mid = left + (right - left) / 2;if(records[mid] == mid) left = mid + 1;else right = mid; }return left == records[left] ? left + 1 : left;}
};

总结

到这里我们二分查找就结束啦,谢谢大家😘😘😘😘(~ ̄▽ ̄)~

在这里插入图片描述

http://www.yayakq.cn/news/969950/

相关文章:

  • 网站文件命名网站建设与管理专业
  • 谁有哪种浏览器网站免费的女生做网站编辑
  • 国有资产处网站建设大连建设工程网站
  • 网站会员和discuz会员同步中牟网络推广
  • 专业关键词优化平台推广关键词如何优化
  • 关于学校网站建设的请示做企业网站建设的公司
  • 天津市建设工程信息网站wordpress网站开发
  • 如何选择模板网站建设网站备案帐号是什么意思
  • 建设厅电工证查询网站官方网搜索广告
  • 做企业网站公司做企业官网需要注意什么
  • 海安网站设计青岛哪家网站建设好
  • ui设计的网站有哪些成都网站建设哪家专业
  • 男的做直播哪个网站网站建设语言
  • 内容管理网站建设方案网站建设的基本教程
  • 自助公益网站建设网站开发培训训
  • 表情包做旧网站中国企业排行榜
  • 做购物平台网站客户体验活动内蒙古自治区住房和城乡建设部网站
  • 网页设计建站订货网站怎么做
  • 如何制作一个自己的网站?创意网页设计
  • 网站后台管理员密码网站设计时多页面切换时什么控件
  • html5产品展示网站模板提升网站知名度
  • 外贸精品网站建设国内最好景观设计公司排名
  • 配置 tomcat 做网站网站开源是什么意思
  • html网站源码下载wordpress外网访问
  • 网站优化推广公司推荐有哪些网站可以免费看
  • 如何用腾讯云建设自己网站pr值高的网站
  • 微网站开发用什么技术新网 网站建立
  • 国内建站 wordpress人寿保险网站
  • 下载网站的表格要钱如何做哪里可以免费申请空间 注册域名 申请网站
  • 网站推广常用方法如何做微信小程序步骤