zoukankan      html  css  js  c++  java
  • 1536. 在排序数组中查找元素的第一个和最后一个位置

    1536. 在排序数组中查找元素的第一个和最后一个位置

    中文English

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

    你的算法时间复杂度必须是 O(log n) 级别。

    如果数组中不存在目标值,返回 [-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]
    
     
     
    输入测试数据 (每行一个参数)如何理解测试数据?

     二分法 + 两个单指针 

    时间复杂度:O(log N)

    空间复杂度:O(1)

    class Solution:
        """
        @param nums: the array of integers
        @param target: 
        @return: the starting and ending position
        """
        def searchRange(self, nums, target):
            # Write your code here.
            #二分法,首先先定位到等于target的位置,然后target两边走,确定起点和终点
            if not nums: return [-1, -1]
            
            #初始化
            x, y = -1, -1 
            length = len(nums)
            start, end = 0, length - 1 
            
            #二分查找
            while start + 1 < end:
                mid = start + (end - start) // 2 
                
                if nums[mid] > target:
                    end = mid 
                elif nums[mid] < target:
                    start = mid
                else:
                    #如果两者相等的话,则开始target找起点和终点
                    left, right = mid, mid 
                    while left >= 0:
                        if (nums[left] == target):
                            x = left
                        else:
                            break
                        left -= 1 
                    
                    while right <= length - 1:
                        if (nums[right] == target):
                            y = right
                        else:
                            break
                        right += 1 
                    break
            
            return [x, y]

     注:lintcode通过,但是测[0,1],1的时候有问题,需要输出[1,1],后面为调式版本

    class Solution:
        """
        @param nums: the array of integers
        @param target: 
        @return: the starting and ending position
        """
        def searchRange(self, nums, target):
            # Write your code here.
            #二分法,首先先定位到等于target的位置,然后target两边走,确定起点和终点
            if not nums: return [-1, -1]
            
            #初始化
            x, y = -1, -1 
            length = len(nums)
            start, end = 0, length - 1 
            left, right = 0, length - 1 
            
            #二分查找
            while start + 1 < end:
                mid = start + (end - start) // 2 
                
                if nums[mid] > target:
                    end = mid 
                elif nums[mid] < target:
                    start = mid
                else:
                    left, right = mid, mid
                    break
            
            if nums[start] == target:
                left, right = start, start 
            elif nums[end] == target:
                left, right = end, end 
            
            #如果两者相等的话,则开始target找起点和终点
            while left >= 0:
                if (nums[left] == target):
                    x = left
                else:
                    break
                left -= 1 
            
            while right <= length - 1:
                if (nums[right] == target):
                    y = right
                else:
                    break
                right += 1 
            
            return [x, y]
  • 相关阅读:
    这次面试就差不多了,你有什么问题需要问我呢?
    C++为啥要使用new
    C#读取“我的文档”等特殊系统路径及环境变量
    C++11 Lambda表达汇总总结
    c#计算 坐标点与坐标点之间的距离
    eclipse svn同步资源库时忽略某些不需要提交文件类型和文件夹
    通俗理解TCP/IP协议三次握手四次分手流程
    mysql 免安装版 启动服务马上关闭
    MySQL数据库安装与配置详解
    word 插入的图片被嵌套在文字底下
  • 原文地址:https://www.cnblogs.com/yunxintryyoubest/p/13200392.html
Copyright © 2011-2022 走看看