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

成都集团网站建设广东vs北京首钢

成都集团网站建设,广东vs北京首钢,win7 iis默认网站设置,站长基地gif网站素材文章目录 1.山脉数组的峰顶索引2.寻找峰值3.寻找旋转排序数组中的最小值4.点名希望读者们多多三连支持小编会继续更新你们的鼓励就是我前进的动力! 本篇接上一篇二分查找,主要通过部分题目熟悉二分查找的进阶使用,重点强调二段性,…

文章目录

  • 1.山脉数组的峰顶索引
  • 2.寻找峰值
  • 3.寻找旋转排序数组中的最小值
  • 4.点名
  • 希望读者们多多三连支持
  • 小编会继续更新
  • 你们的鼓励就是我前进的动力!

本篇接上一篇二分查找,主要通过部分题目熟悉二分查找的进阶使用,重点强调二段性,找到两个区间不同的地方在哪,多画图划分界限

1.山脉数组的峰顶索引

✏️题目描述:

在这里插入图片描述

✏️示例:

在这里插入图片描述

传送门:山脉数组的峰顶索引

题解:
💻第一步:

首先确定二段性,把顶峰放到左区间还是右区间取决于你自己,会根据取法不同而导致代码不同,但是都能求出顶峰索引,这里我们放到左区间

在这里插入图片描述

💻第二步:

按照我们的划分方式,要确保左边区间不会越过分界,右边区间同理,就要用midmid-1这种划分方式。如果在左区间,那么mid会有等于峰顶索引,即left = mid;如果在右区间mid及其后面的值都不可能是峰顶索引,即right = mid - 1

在这里插入图片描述

💻细节问题:

对于二分查找进阶模版,如果在if语句的函数体里有减法操作时,那么计算mid的公式就要+1

💻代码实现:

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

2.寻找峰值

✏️题目描述:

在这里插入图片描述

✏️示例:

在这里插入图片描述

传送门:寻找峰值

题解:
💻第一步:

首先确定二段性,可以分为在上坡或者下坡,其实这道题和山脉数组的峰顶索引是一样的,这里我们顶峰放在右区间里

在这里插入图片描述

💻第二步:

按照我们的划分方式,要确保右边区间不会越过分界,左边区间同理,就要用midmid+1这种划分方式。如果在右区间,那么mid会有等于峰顶索引,即right = mid;如果在左区间mid及其前面的值都不可能是峰顶索引,即left = mid + 1

在这里插入图片描述
💻代码实现:

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

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

✏️题目描述:

在这里插入图片描述

✏️示例:

在这里插入图片描述

传送门:寻找旋转排序数组中的最小值

题解:
💻第一步:

根据画图,似乎不太好确认二段性,但我们可以发现以D点为分界点左区间的数(A到B)都大于D右区间的数(C到D)都小于D,那么由此就能确定二段性,不断向中寻找最小的数

在这里插入图片描述

💻第二步:

如果在右区间,那么mid会有等于最小值,即right = mid;如果在左区间,mid及其前面的值都不可能是最小值,即left = mid + 1

在这里插入图片描述

💻代码实现:

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

4.点名

✏️题目描述:

在这里插入图片描述

✏️示例:

在这里插入图片描述

传送门:点名

题解:
💻第一步:

连续数组的前提下,缺失数字的位置开始下标与实际值不同,很明显二段性立马就出来了

在这里插入图片描述

💻第二步:

如果在右区间,那么mid会有等于缺失值的实际位置索引,即right = mid;如果在左区间,mid及其前面的值都不可能是缺失值的实际位置索引,即left = mid + 1

在这里插入图片描述

💻代码实现:

#include <iostream>
#include <vector>
using namespace std;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 records[left] == left ? left + 1 : left;}
};

希望读者们多多三连支持

小编会继续更新

你们的鼓励就是我前进的动力!

请添加图片描述

http://www.mmbaike.com/news/37991.html

相关文章:

  • 定制网站开发蒙特灰色关键词代发可测试
  • 个人网站可以做哪些主题百度网盘网站入口
  • 政府网站集群建设汇报企业软文怎么写
  • 公司的网站建设费进入什么科目昆明优化网站公司
  • 网站的用户运营值得做吗盘多多网盘资源库
  • 好的网站模板种子搜索引擎
  • app网站公司网站推广的10种方法
  • 公司管理制度完整版aso排名优化知识
  • 大连企业建站系统脚上起小水泡还很痒是怎么回事
  • wordpress上传至哪个目录下安卓优化大师hd
  • 网站开发语言是什么网址域名
  • 商丘小程序开发公司seo对各类网站的作用
  • 怎么做帖子网站销售渠道都有哪些
  • java做教程网站营销咨询公司经营范围
  • 做的网站缩小内容就全乱了百度权重查询网址
  • 企业网站的基本内容制作公司网站的公司
  • 汉中做网站营业推广的方式
  • 北京市住房和城乡建设委员会的网站谁能给我个网址
  • 做网站前景google play 应用商店
  • vs做网站如何输出网站出租三级域名费用
  • 深圳网站建设 案例发新闻稿平台
  • 学做新疆菜的网站原创文章代写平台
  • dede程序网站如何查看百度蜘蛛国际羽联最新排名
  • 南昌网站建设哪家最好竞价推广和seo的区别
  • 林州网站建设策划seo营销策略
  • b站推广网站入口无病毒推广代理登录页面
  • 中国十大管理咨询公司怎么做好seo推广
  • 南宁模板建站多少钱5118站长工具
  • 网站建设在马来西亚上海网络推广软件
  • wordpress首页跳出广告seo数据统计分析工具有哪些