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

淮安市城市建设档案馆网站平度建设局网站

淮安市城市建设档案馆网站,平度建设局网站,兰州做网站公司es5188,网站建设发布设需求每天一题,防止痴呆题目示例分析思路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/743064/

相关文章:

  • 金湖县建设局网站百度老年搜索
  • 深圳建设集团网站首页设计师个人网站主页
  • 南通网站建设找哪家好网站关键词重要吗
  • 成都鱼羊环保网站制作设计做网站建设的工资高吗
  • 颍上做网站网站seo 教程
  • 深圳医疗网站建设报价莱芜网络营销
  • 济宁网站建设兼职织梦怎么做淘客网站
  • 淘宝上 网站建设团购网站优化
  • 广州市门户网站建设品牌wordpress用户注册添加密码
  • 李沧建网站公司wordpress底面有虚线这么办
  • 做垂直类网站抚州购物网站开发设计
  • 德州公司做网站dw旅游网站怎么做
  • 网站建设合同要不要交印花税网络推广平台排行榜
  • 网站开发需要会什么wordpress img相对路径
  • 网站建设有什么技术网站有哪些元素组成
  • 沈阳网站制作找网势科技做网站开发能挣钱
  • 山东建设监理协会网站无法登录做直播网站前端
  • 加强网站建设的制度做调研有哪些网站
  • 工信部备案网站查询用什么做响应式网站
  • 建网站拿到广告海外制作网站
  • 游戏网站开发运营的几个思路做影视网站需要境外
  • 云南南网站开发设计公司企业愿景
  • 重庆网站建设设计公司信息西北苗木网陕西泽基生态建设有限公司网站
  • 系部网站建设标准咸宁网站设计制作
  • 网站面试通知表格怎么做精品应用下载安装
  • 赣州住房和建设局网站wordpress插件jetpack
  • 广东网站建设公司电话网络框架
  • 南昌网站seo厂家什么蓝色 适合公司网站主色
  • 做互联网需要网站吗开封旅游网站建设方案策划书
  • 网站制作找云优化上海企业登记在线服务平台