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

上海网站建设领导品牌seo怎么优化简述

上海网站建设领导品牌,seo怎么优化简述,潮州哪里做网站,网站源码做exe执行程序题目 给你一个按照非递减顺序排列的整数数组 nums,和一个目标值 target。请你找出给定目标值在数组中的开始位置和结束位置。 如果数组中不存在目标值 target,返回 [-1, -1]。 你必须设计并实现时间复杂度为 O(log n) 的算法解决此问题。 示例 1&…

题目

给你一个按照非递减顺序排列的整数数组 nums,和一个目标值 target。请你找出给定目标值在数组中的开始位置和结束位置。

如果数组中不存在目标值 target,返回 [-1, -1]。

你必须设计并实现时间复杂度为 O(log n) 的算法解决此问题。

示例 1:

输入:nums = [5,7,7,8,8,10], target = 8
输出:[3,4]

示例 2:

输入:nums = [5,7,7,8,8,10], target = 6
输出:[-1,-1]

示例 3:

输入:nums = [], target = 0
输出:[-1,-1]

提示:

0 <= nums.length <= 105
-109 <= nums[i] <= 109
nums 是一个非递减数组
-109 <= target <= 109

代码

class Solution {
public int[] searchRange(int[] nums, int target) {
int leftBorder = getLeftBorder(nums, target);
int rightBorder = getRightBorder(nums, target);
// 情况一
if (leftBorder == -2 || rightBorder == -2) return new int[]{-1, -1};
// 情况三
if (rightBorder - leftBorder > 1) return new int[]{leftBorder + 1, rightBorder - 1};
// 情况二
return new int[]{-1, -1};}
int getRightBorder(int[] nums, int target) {
int left = 0;
int right = nums.length - 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的时候更新left
left = middle + 1;
rightBorder = left;
}
}
return rightBorder;
}

int getLeftBorder(int[] nums, int target) {int left = 0;int right = nums.length - 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 int[] searchRange(int[] nums, int target) {
int left = 0;
int right = nums.length - 1;
int first = -1;
int last = -1;
// 找第一个等于target的位置
while (left <= right) {
int middle = (left + right) / 2;
if (nums[middle] == target) {
first = middle;
right = middle - 1; //重点
} else if (nums[middle] > target) {
right = middle - 1;
} else {
left = middle + 1;
}
}

// 最后一个等于target的位置
left = 0;
right = nums.length - 1;
while (left <= right) {int middle = (left + right) / 2;if (nums[middle] == target) {last = middle;left = middle + 1; //重点} else if (nums[middle] > target) {right = middle - 1;} else {left = middle + 1;}
}return new int[]{first, last};
}

}
第一部分:找第一个等于target的位置
if (nums[middle] == target) {
first = middle;
right = middle - 1; //重点
}
在这里,当我们找到了一个等于target的元素时,我们并不立即停止搜索。相反,我们将right更新为middle - 1,即把右边界移动到中间位置的左边一位。这样做是为了继续在当前middle位置的左侧查找是否有更早出现的target。通过不断将右边界向左移动,我们可以确保最终找到的是数组中最左边的那个target。
第二部分:找最后一个等于target的位置
java
深色版本

if (nums[middle] == target) {
last = middle;
left = middle + 1; //重点
}
同样的逻辑应用于此处,但这次我们对左边界进行操作。当找到一个等于target的元素时,我们将left更新为middle + 1,即把左边界移动到中间位置的右边一位。这使得我们可以在当前middle位置的右侧继续查找是否存在更晚出现的target。通过不断将左边界向右移动,我们可以确保最终找到的是数组中最右边的那个target。

http://www.dinnco.com/news/25340.html

相关文章:

  • 利用ionic做的网站武汉网络推广广告公司
  • 求生之路2怎么做非官方网站网站买卖
  • 世赛网站开发博客seo怎么做
  • 驻马店市旅游网站建设培训心得总结怎么写
  • 自己建网站免费最近七天的新闻重点
  • 建设网站是否等于开展网络营销自动seo优化
  • 美食烹饪网站策划书新网站推广方法
  • 艾融软件是外包公司么seo是怎么优化的
  • 免费搭建网站平台百度网站的优化方案
  • 用php做美食网站有哪些百度一下官网网址
  • 南宁网站建设超薄网络大数据分析培训机构
  • 价格优化网站建设济南竞价托管公司
  • 学做美食视频在哪个网站如何建立一个网站平台
  • 定制开发电商网站建设哪家好网站怎么收录到百度
  • 杭州h5建站seo查询 站长工具
  • 高校网站建设汇报民宿平台搜索量上涨
  • 班级网站源代码怎么做seo
  • 海尔公司的网站建设百度秒收录神器
  • 邯郸网站设计费用seo推广工具
  • 给博彩网站做优化人民网舆情数据中心官网
  • 网站建设专业英文无代码系统搭建平台
  • Wordpress刷新CDN缓存专业全网优化
  • 2023中国互联网公司排行榜优化大师的作用
  • 网页设计实验报告操作步骤seo优化技巧
  • 做商城网站要什么证件店铺推广渠道有哪些方式
  • 网站推广软文范例seo销售代表招聘
  • 试玩做任务赚钱的网站如何在各种网站投放广告
  • 网站开发与设计实验报告总结班级优化大师官网下载
  • 做视频网站成本广州seo网站推广公司
  • 网站的交互性google官网登录入口