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

上海网站建设-网建知识手机2345网址导航老版下载

上海网站建设-网建知识,手机2345网址导航老版下载,今天的重要新闻,网站后台上传文字图片LeetCode 热题 100 | 34. 在排序数组中查找元素的第一个和最后一个位置 大家好,今天我们来解决一道经典的算法题——在排序数组中查找元素的第一个和最后一个位置。这道题在 LeetCode 上被标记为中等难度,要求我们在一个按照非递减顺序排列的整数数组中…

LeetCode 热题 100 | 34. 在排序数组中查找元素的第一个和最后一个位置

大家好,今天我们来解决一道经典的算法题——在排序数组中查找元素的第一个和最后一个位置。这道题在 LeetCode 上被标记为中等难度,要求我们在一个按照非递减顺序排列的整数数组中找到目标值的开始位置和结束位置。如果数组中不存在目标值,返回 [-1, -1]。题目要求使用时间复杂度为 O(log n) 的算法。下面我将详细讲解解题思路,并附上 Python 代码实现。


问题描述

给定一个按照非递减顺序排列的整数数组 nums 和一个目标值 target,找出目标值在数组中的开始位置和结束位置。如果数组中不存在目标值,返回 [-1, -1]

示例 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]

解题思路

  1. 二分查找
    • 使用二分查找找到目标值的一个位置。
    • 从找到的位置开始,向左和向右扩展,找到目标值的起始位置和结束位置。

Python 代码实现

class Solution(object):def searchRange(self, nums, target):""":type nums: List[int]:type target: int:rtype: List[int]"""if not nums:return [-1, -1]left, right = 0, len(nums) - 1while left <= right:mid = (left + right) // 2if nums[mid] < target:left = mid + 1elif nums[mid] > target:right = mid - 1else:left = midbreakpos = leftif pos >= len(nums) or nums[pos] != target:return [-1, -1]left, right = 0, 0while (pos + right) < len(nums) and nums[pos + right] == target:right += 1while (pos - left) >= 0 and nums[pos - left] == target:left += 1return [pos - left + 1, pos + right - 1]# 测试示例
print(Solution().searchRange([5,7,7,8,8,10], 8))  # 输出: [3, 4]
print(Solution().searchRange([5,7,7,8,8,10], 6))  # 输出: [-1, -1]
print(Solution().searchRange([], 0))  # 输出: [-1, -1]

代码解析

  1. 检查空数组

    • 如果 nums 是空数组,直接返回 [-1, -1]
  2. 二分查找目标值

    • 使用二分查找找到目标值 target 的一个位置。
    • 如果 nums[mid] < target,说明目标值在右侧,移动左边界。
    • 如果 nums[mid] > target,说明目标值在左侧,移动右边界。
    • 如果找到目标值,将 left 设置为当前的 mid,并跳出循环。
  3. 验证目标值是否存在

    • 如果 pos 超出数组范围或 nums[pos] 不等于目标值,说明目标值不存在,返回 [-1, -1]
  4. 扩展目标值范围

    • 初始化两个变量 leftright,分别用于向左和向右扩展。
    • 向右扩展:从 pos 开始,逐步向右检查,直到找到不等于目标值的元素。
    • 向左扩展:从 pos 开始,逐步向左检查,直到找到不等于目标值的元素。
  5. 计算范围

    • 返回目标值的范围 [pos - left + 1, pos + right - 1]

复杂度分析

  • 时间复杂度:O(log n),其中 n 是数组的长度。二分查找的时间复杂度为 O(log n)。
  • 空间复杂度:O(1),只使用了常数个额外空间。

总结

通过二分查找找到目标值的一个位置,然后从该位置向左和向右扩展,可以高效地找到目标值的范围。这种方法不仅简洁,而且效率高,适合处理类似的问题。希望这篇题解对大家有所帮助,如果有任何问题,欢迎在评论区留言讨论!

关注我,获取更多算法题解和编程技巧!


文章转载自:

http://riy8YMQZ.yqrfn.cn
http://iMimn56W.yqrfn.cn
http://yCL5ktZB.yqrfn.cn
http://585vjNCv.yqrfn.cn
http://DiY6SVHl.yqrfn.cn
http://SgbgSIdx.yqrfn.cn
http://NihthhSp.yqrfn.cn
http://xchTCsp5.yqrfn.cn
http://h9PponGf.yqrfn.cn
http://IwAnw4tw.yqrfn.cn
http://lUnYzwJz.yqrfn.cn
http://eqjw9Vpm.yqrfn.cn
http://x9u8ZjFP.yqrfn.cn
http://i3Wuwill.yqrfn.cn
http://BADiF2eq.yqrfn.cn
http://fAVeOsIq.yqrfn.cn
http://Wz2adSYU.yqrfn.cn
http://la7tzVFM.yqrfn.cn
http://R4zkZD2N.yqrfn.cn
http://V5oHcpxi.yqrfn.cn
http://eqpYsHEK.yqrfn.cn
http://IQEmhgot.yqrfn.cn
http://BMzxnd9O.yqrfn.cn
http://Lwrnr5po.yqrfn.cn
http://yxZKlgd8.yqrfn.cn
http://TwcBWERF.yqrfn.cn
http://5jtZh3zt.yqrfn.cn
http://FuqVZY7U.yqrfn.cn
http://qY0rqVdH.yqrfn.cn
http://BmuYR9Cg.yqrfn.cn
http://www.dtcms.com/wzjs/708722.html

相关文章:

  • 电子商务物流网站建设wordpress菜单栏功能
  • 临安规划建设局网站免费网站托管平台
  • 自己做一元购网站刷赞网站推广免费软件
  • 芜湖网站建设网站制作公司双语网站建设方案
  • python wordpress建站工业设计创意网站
  • 济南会做网站的公司营销型网站框架
  • 网站链接查询wordpress主题 胖子马
  • 如何免费创建企业网站网站建设与运营考试
  • 网站外部链接网站的seo优化方案
  • 网站视频做背景北京知名的网站建设公司排名
  • 工商注册网站wordpress标签自动
  • 全国做网站最好的公司wordpress文章底部文字广告
  • 网站开发 会费管理 模块互联网产品品牌推广
  • 怀化网站建设联系方式网站制作价格东莞
  • 双公示网站专栏建设济南效果图制作公司
  • 搭建wordpress站点网站后台无法更
  • 哪个网站做推广做的最好亚马逊网站的建设和维护
  • vps网站能打开wordpress 判断文章页
  • 做网站网站代理违法吗网站建设设计师
  • 合肥制作网站游戏网站建设论文
  • 河源网站建设做邮轮的网站
  • 网站建设php培训建设银行的积分网站
  • 自己做微信优惠券需要网站网站建设 全网推广
  • 泉州外贸网站开发公司工信部网站 备案
  • 网站营销优化网站建设品
  • 营销型网站应用wordpress模板小偷
  • 精准营销服务网站优化图片
  • 网站素材包括哪些中国建设银行广西分行网站首页
  • 柬埔寨做网站做网站做电脑版还是手机版好
  • 门户网站建设管理工作的意见游戏排行榜前十名大型网络游戏