LeetCode 第34、35题

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

题目描述

给你一个按照非递减顺序排列的整数数组nums,和一个目标值target。请你找出给定目标值在数组中的开始位置和结束位置。如果数组中不存在目标值target,返回[-1,1]。你必须设计并实现时间复杂度为为O(log n)的算法解决此问题。

难度:中等

题目链接34. 在排序数组中查找元素的第一个和最后一个位置 - 力扣(LeetCode)
示例1:

cs 复制代码
输入:nums = [5,7,7,8,8,10], target = 8
输出:[3,4]

示例2:

cs 复制代码
输入:nums = [5,7,7,8,8,10], target = 6
输出:[-1,-1]

示例3:

cs 复制代码
输入:nums = [], target = 0
输出:[-1,-1]

提示:

  • 0<=nums.length<=105
  • -109<=nums[i]<=109
  • nums是一个非递减数组
  • -109<=target<=109
    解题思路:二分查找

关键点:

  • 寻找左边界时,即使找到目标值也继续向左搜索
  • 寻找右边界时,即使找到目标值也继续向右搜索
  • 两次二分查找的条件稍有不同
cs 复制代码
int binarySearch(int* nums,int numsSize,int target,bool lower)
{
    int left = 0,right = numsSize-1,ans = numsSize;
    while(left<=right)
    {
        int mid=(left+right)/2;
        if(nums[mid]>target || (lower && nums[mid] >=target))
        {
            right = mid-1;ans=mid;
        }else
           left=mid+1;

    }
    return ans;
}

int* searchRange(int* nums,int numsSize,int target,int* returnSize)
{
    int leftIdx = binarySearch(nums,numsSize,target,true);
    int rightIdx = binarySearch(nums,numsSize,target,false)-1;
    int* ret = malloc(sizeof(int)*2);
    *returnSize=2;
    if(leftIdx<=rightIdx && rightIdx<numsSize && nums[leftIdx]==target && nums[rightIdx]==target)
    {
        ret[0]=leftIdx,ret[1]=rightIdx;
        return ret;
    }
    ret[0]=-1,ret[1]=-1;
    return ret;
}

返回的left永远是首个大于等于target的数的位置,right永远是首个小于target的数的位置,左边界按正常查找,右边查target+0.5即可。5

cs 复制代码
int binSearch(vector<int>& nums,double target)
{
    int n=nums.size();
    int left = 0,right = n-1;
    while(left<=right)
    {
        int mid = (left+right)/2;
        if(nums[mid]>=target) right = mid-1;
        else left = mid+1;

    }
    return left;
}
public:
vector<int> searchRange(vector<int>& nums,int target)
{
    if(nums.size()==0) return {-1,-1};
    int l = binSearch(nums,target);
    int r=binSearch(nums,target+0.5)-1;
    if(l>=nums.size() || r<0 || l>r)  return {-1,-1};
    return {l,r};

}

LeetCode 第35题:搜索插入位置

题目描述

给定一个排序数组和一个目标值,在数组中找到目标值,并返回其索引。如果目标值不存在于数组中,返回它将会被按顺序插入的位置。请必须使用时间复杂度为O(log n)的算法。

难度:简单

题目链接35. 搜索插入位置 - 力扣(LeetCode)
示例1:

cs 复制代码
输入: nums = [1,3,5,6], target = 5
输出: 2

示例2:

cs 复制代码
输入: nums = [1,3,5,6], target = 2
输出: 1

示例3:

cs 复制代码
输入: nums = [1,3,5,6], target = 7
输出: 4

示例4:

cs 复制代码
输入: nums = [1,3,5,6], target = 0
输出: 0

提示:

  • 1 <= nums.length <= 104

  • -104 <= nums[i] <= 104

  • nums 为 无重复元素升序 排列数组

  • -104 <= target <= 104
    解题思路:二分查找

  • 初始化左右指针

  • 进行二分查找

  • 如果找到目标值,直接返回

  • 如果找不到,返回left指针位置

cs 复制代码
int searchInsert(int* nums, int numsSize, int target)
{
    int left = 0,right = numsSize-1;
    while(left<=right)
    {
        int mid = left+(right-left)/2;
        if(nums[mid] == target)  return mid;
        else if(nums[mid]<target)  left = mid +1;
        else  right = mid-1;
        
    }
    return left;
}
相关推荐
Charlie_lll6 分钟前
力扣解题-移动零
后端·算法·leetcode
chaser&upper7 分钟前
矩阵革命:在 AtomGit 解码 CANN ops-nn 如何构建 AIGC 的“线性基石”
程序人生·算法
weixin_4997715516 分钟前
C++中的组合模式
开发语言·c++·算法
iAkuya1 小时前
(leetcode)力扣100 62N皇后问题 (普通回溯(使用set存储),位运算回溯)
算法·leetcode·职场和发展
近津薪荼1 小时前
dfs专题5——(二叉搜索树中第 K 小的元素)
c++·学习·算法·深度优先
xiaoye-duck1 小时前
吃透 C++ STL list:从基础使用到特性对比,解锁链表容器高效用法
c++·算法·stl
松☆1 小时前
CANN与大模型推理:在边缘端高效运行7B参数语言模型的实践指南
人工智能·算法·语言模型
java干货1 小时前
为什么 “File 10“ 排在 “File 2“ 前面?解决文件名排序的终极算法:自然排序
开发语言·python·算法
皮皮哎哟1 小时前
数据结构:嵌入式常用排序与查找算法精讲
数据结构·算法·排序算法·二分查找·快速排序
程序员清洒1 小时前
CANN模型剪枝:从敏感度感知到硬件稀疏加速的全链路压缩实战
算法·机器学习·剪枝