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

北京做erp报价的网站wordpress 表情插件

北京做erp报价的网站,wordpress 表情插件,做网站用的主机多少合适,台州网站建设策划每天一题,防止痴呆题目示例分析思路1题解1👉️ 力扣原文 题目 给你一个按照非递减顺序排列的整数数组 nums,和一个目标值 target。请你找出给定目标值在数组中的开始位置和结束位置。 如果数组中不存在目标值 target,返回 [-1,…

每天一题,防止痴呆

  • 题目
  • 示例
  • 分析思路1
  • 题解1

👉️ 力扣原文

题目

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

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

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

示例

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

分析思路1

1.使用二分查找算法,找到元素第一次出现的位置。这里可以用一个变量记录当前找到的最小位置,每次找到目标元素时,更新这个变量,继续在左侧查找,直到左侧没有目标元素为止。

2.使用二分查找算法,找到元素最后一次出现的位置。这里可以用一个变量记录当前找到的最大位置,每次找到目标元素时,更新这个变量,继续在右侧查找,直到右侧没有目标元素为止。

为什么findLef中tint mid = left + (right - left) / 2;?
计算机中,整数的表示是有限的,如果两个很大的整数相加,可能会导致结果超出整数类型的表示范围,发生整数溢出。例如,如果 left 和 right 都很大,它们的和可能会超出 int 类型的最大值,导致结果变成负数或者其他的不正确的结果。因此,在计算中间位置时,如果直接采用 (right + left) / 2 的方法来计算中间位置,可能会导致整数溢出的问题。而采用 (right - left) / 2 的方法来计算中间位置,则可以避免这个问题的出现,因为 right 和 left 的差值不会超过 int 类型的表示范围,所以计算结果也不会超出 int 类型的范围。

为什么findRight中int mid = left + (right - left + 1) / 2;?
这是因为在二分查找中,当左右边界相邻时,如果中间位置的计算公式为 int mid = left + (right - left) / 2;,那么会出现死循环的情况。因为此时 left 和 right 都指向同一个位置,而中间位置的计算公式为 (left + right) / 2,会一直得到这个位置,而不会结束循环。
为了避免这种情况,我们可以将计算中间位置的公式修改为 int mid = left + (right - left + 1) / 2;,这样在左右边界相邻时,中间位置会取右边界的位置,从而结束循环。

题解1

class Solution {public int[] searchRange(int[] nums, int target) {int[] result = new int[]{-1, -1};if (nums == null || nums.length == 0) {return result;}int left = 0, right = nums.length - 1;while (left <= right) {int mid = left + (right - left) / 2;if (nums[mid] == target) {result[0] = findLeft(nums, target, left, mid);result[1] = findRight(nums, target, mid, right);break;} else if (nums[mid] < target) {left = mid + 1;} else {right = mid - 1;}}return result;}private int findLeft(int[] nums, int target, int left, int right) {while (left < right) {int mid = left + (right - left) / 2;if (nums[mid] == target) {right = mid;} else {left = mid + 1;}}return nums[left] == target ? left : -1;}private int findRight(int[] nums, int target, int left, int right) {while (left < right) {int mid = left + (right - left + 1) / 2;if (nums[mid] == target) {left = mid;} else {right = mid - 1;}}return nums[left] == target ? left : -1;}}

执行结果
在这里插入图片描述

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

相关文章:

  • 在线做效果图的网站网站推广与优化怎么做
  • 6做网站网站代码优化方案
  • 减肥网站开发目的雅安公司做网站
  • 竞网网站建设网店推广费用多少钱
  • 漳州市东山县建设局网站代做备案网站
  • 路由器做映射后 内网可以访问到我的网站 但是外网无法访问工业品一站式采购平台
  • 网站备案法律福田住房和建设局网站
  • 吉林省住房和城乡建设厅网站6wordpress文章图片显示不出
  • 自己做网站的二维码art2008cms网站开发
  • 做网站公司费用用凡科网建设的网站
  • 网站建网站建站现在推广网站最好的方式
  • 网站后台如何上传图片微信网站开发服务外包
  • 关键词与网站标题关键词seo排名优化
  • 企业网站都是静态的吗wordpress 编辑页脚
  • 怎么做旅游网站中天建设集团有限公司电话号码
  • 徐州网站建设公司哪个好做网站的自我介绍
  • 网站建设规划方案.ppt成全视频在线观看免费高清动漫
  • 阿里巴巴建设网站服饰 公司 网站建设
  • 靖江网站建设众筹插件 wordpress
  • 查网站开发语言php创建网页
  • 一个网站有多大深圳网站建设费用大概多少
  • 高端网站的设计开发公司搜索引擎排名优化公司
  • 哪里建网站性价比高网站建设的背景及意义
  • 做织带的网站设计网站建设价格
  • 做一套二级域名网站怎么做山东聊城建设局网站
  • 网站卖了对方做违法吗企业网站设计建设长春
  • 网站建设管理情况番禺seo
  • 教学网站建设目的网站建站和推广服务公司
  • 北京网站建设网站开发中国建筑网官网企业愿景
  • 重庆网站关键词排名优化上海58同城招聘网最新招聘