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

网站手机微信三合一怎么做网站百度不收录的原因

网站手机微信三合一怎么做,网站百度不收录的原因,动态网站建设包括哪些,吉林网站制作第一此次想到的解法是首先使用二分查找在排序数组中查找到一个指定元素&#xff0c;随后对该元素左右进行遍历&#xff0c;找到起始位置和结束位置&#xff0c;代码如下&#xff1a; class Solution { public:vector<int> searchRange(vector<int>& nums, int…

第一此次想到的解法是首先使用二分查找在排序数组中查找到一个指定元素,随后对该元素左右进行遍历,找到起始位置和结束位置,代码如下:

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

执行虽然通过,但测试用时并不是很理想,在 代码随想录 看到的解法是将题目分为三种情况:

  • 情况一:target 在数组范围的右边或者左边,例如数组{3, 4, 5},target为2或者数组{3, 4, 5},target为6,此时应该返回{-1, -1}
  • 情况二:target 在数组范围中,且数组中不存在target,例如数组{3,6,7},target为5,此时应该返回{-1, -1}
  • 情况三:target 在数组范围中,且数组中存在target,例如数组{3,6,7},target为6,此时应该返回{1, 1}

采用二分法来分别寻找左边界和右边界,最终分情况进行return。代码如下:

class Solution {
public:vector<int> searchRange(vector<int>& nums, int target) {int leftBorder = getLeftBorder(nums, target);int rightBorder = getRightBorder(nums, target);// 情况一if (leftBorder == -2 || rightBorder == -2) return {-1, -1};// 情况三if (rightBorder - leftBorder > 1) return {leftBorder + 1, rightBorder - 1};// 情况二return {-1, -1};}
private:int getRightBorder(vector<int>& nums, int target) {int left = 0;int right = nums.size() - 1;int rightBorder = -2; // 记录一下rightBorder没有被赋值的情况while (left <= right) {int middle = left + ((right - left) / 2);if (nums[middle] > target) {right = middle - 1;} else { // 寻找右边界,nums[middle] == target的时候更新leftleft = middle + 1;rightBorder = left;}}return rightBorder;}int getLeftBorder(vector<int>& nums, int target) {int left = 0;int right = nums.size() - 1;int leftBorder = -2; // 记录一下leftBorder没有被赋值的情况while (left <= right) {int middle = left + ((right - left) / 2);if (nums[middle] >= target) { // 寻找左边界,nums[middle] == target的时候更新rightright = middle - 1;leftBorder = right;} else {left = middle + 1;}}return leftBorder;}
};

将上述代码的两个二分查找函数进行合并:

class Solution {
public:vector<int> searchRange(vector<int>& nums, int target) {int leftBorder = getBorder(nums, target, true);int rightBorder = getBorder(nums, target, false);// 情况一if (leftBorder == -2 || rightBorder == -2) return {-1, -1};// 情况三if (rightBorder - leftBorder > 1) return {leftBorder + 1, rightBorder - 1};// 情况二return {-1, -1};}
private:int getBorder(vector<int>& nums, int target, bool flag) {int left = 0;int right = nums.size() - 1;int border = -2;while (left <= right){int middle = left + (right - left)/2;if(flag) { //flag = true,返回左边界if (nums[middle] >= target) { // 寻找左边界,nums[middle] == target的时候更新rightright = middle - 1;border = right;} else {left = middle + 1;}}else{if (nums[middle] > target) {right = middle - 1;} else { // 寻找右边界,nums[middle] == target的时候更新leftleft = middle + 1;border = left;}}}return border;}};
http://www.qdjiajiao.com/news/10176.html

相关文章:

  • python网站开发实例教程电商平台运营方案思路
  • 有没有专门做蛋糕的网站推广关键词排名
  • 做网站开发用哪门语言合肥全网推广
  • 宜州做网站需要多少钱2023年8月新冠
  • 网站建设与管理案例...it行业培训机构一般多少钱
  • 专业网站建设微信网站定制网站制作多少钱
  • 主机屋网站搭建设置湖南网站托管
  • .net 网站自动登录全网优化推广
  • 旅游网站模板下载爱站网ip反查域名
  • 改行做网站销售营销方案100例
  • 石家庄网站建设推广公司报价百度一下搜索
  • 淘宝网站首页怎么做学it什么培训机构好
  • 建立网站的原因小学生收集的新闻10条
  • 网站动态添加广告怎么做的cps游戏推广平台
  • seo营销型网站设计要点培训心得体会1000字
  • 住建部网站2015年城市建设统计广东seo推广费用
  • 工厂招工信息苏州百度搜索排名优化
  • 有域名如何做网站软文推广范文
  • 什么网站做外链优化好whois查询 站长工具
  • 纯css做网站北京最新消息今天
  • 最近热点新闻事件2023长沙seo优化排名推广
  • 做网站的软件公司大数据统计网站
  • 山东济南最新疫情爆发成都seo外包
  • android studio手机版windows优化大师卸载不了
  • 直播型网站开发金华网站建设
  • 河北建设网站网站点击快速排名
  • 做海岛旅游类网站的背景及意义威海seo公司
  • 网站建设怎么评估网站推广宣传语
  • 前端开发和网站建设市场调研分析报告范文
  • 网站地图什么意思南京企业网站排名优化