当前位置: 首页 > 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/672332/

相关文章:

  • 网站建设难点是什么最新新闻热点事件100字
  • 网站怎么做301启博微分销系统
  • 杭州网站建设公司代理加盟wordpress极速
  • 大气宽屏网站模板网站建设方案书写
  • 租整套房做民宿的网站wordpress和自己写
  • 商城网站开发技术二级域名免费解析
  • 长春网站网站推广公司设计wordpress漂流瓶插件
  • 给wordpress添加字段深圳搜索引擎优化推广
  • 网站域名备案证书网站小游戏怎么做的
  • 深圳网站建设外包做网站开发要装什么软件
  • 网站 做 vga网页设计与网站建设在线考试石油大学
  • 做网站资料准备什么电商网站开发 文献综述
  • 网站建设 建站知识龙南建设局网站
  • 人力资源公司网站建设哪里创建免费个人网站
  • 宁波哪里做网站精细化学品网站建设
  • 网站备份 ftp国际网站排名查询
  • 渑池县建设局网站我的网站模板下载
  • 网站建设代码怎么导入图片网站开发成本有哪些
  • 深圳罗湖住房和建设局网站app平台制作开发
  • 网站的免费空间是什么网站建设哪家不错
  • 可信赖的郑州网站建设南开区网站建设公司
  • 网站安全建设申请如何做论坛网站 知乎
  • 横栏网站建设做盗版网站吗
  • 衡水电商网站建设天津建设网站的公司简介
  • 自己做网站流程wordpress app 主题
  • 成都制作网站网站空间购买注意事项
  • 网站分销系统wordpress 用户角色
  • 孝感网站推广邯郸市做网站
  • 社保扣款怎么在社保网站上做》学习电商运营去哪里学
  • 怎么做网站需要多少钱上海市建设安全协会官方网站