Leetcode—34.在排序数组中查找元素的第一个和最后一个位置【中等】

2023每日刷题(六)

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

实现代码

c 复制代码
/**
 * Note: The returned array must be malloced, assume caller calls free().
 */
int lower_bound(int *arr, int numsSize, int target) {
    // 左闭右开区间[left, target)
    int left = 0, right = numsSize;
    int mid;
    while(left < right) {
        mid = left + (right - left) / 2;
        if(arr[mid] < target) {
            left = mid + 1;
        } else {
            right = mid;
        }
    }
    return left;
}


int* searchRange(int* nums, int numsSize, int target, int* returnSize){
    int *ans = (int *)malloc(sizeof(int) * 2);
    *returnSize = 2;
    ans[0] = -1;
    ans[1] = -1;
    int left = lower_bound(nums, numsSize, target);
    int right = lower_bound(nums, numsSize, target + 1) - 1;
    if(numsSize != 0 && left != numsSize && nums[left] == target) {
        ans[0] = left;
        ans[1] = right;
    } 
    return ans;
}

运行结果


之后我会持续更新,如果喜欢我的文章,请记得一键三连哦,点赞关注收藏,你的每一个赞每一份关注每一次收藏都将是我前进路上的无限动力 !!!↖(▔▽▔)↗感谢支持!

相关推荐
造梦师阿鹏22 分钟前
004.从 API 裸调到 LangChain
经验分享·ai·大模型·ai技术·大模型应用开发
地平线开发者35 分钟前
征程 6 | PTQ 精度调优辅助代码,总有你用得上的
算法·自动驾驶
Tisfy1 小时前
LeetCode 837.新 21 点:动态规划+滑动窗口
数学·算法·leetcode·动态规划·dp·滑动窗口·概率
慧翔天地人才发展学苑1 小时前
大厂 | 华为半导体业务部2026届秋招启动
华为·面试·职场和发展·跳槽·求职招聘·职场晋升
CoovallyAIHub2 小时前
为高空安全上双保险!无人机AI护航,YOLOv5秒判安全带,守护施工生命线
深度学习·算法·计算机视觉
huangzixuan10072 小时前
08.18总结
算法·深度优先·图论
逆向菜鸟2 小时前
【摧毁比特币】椭圆曲线象限细分求k-陈墨仙
python·算法
DolphinDB2 小时前
DolphinDB 回测插件快速上手
算法
利刃大大2 小时前
【动态规划:路径问题】最小路径和 && 地下城游戏
算法·动态规划·cpp·路径问题
武大打工仔3 小时前
用 Java 复现哲学家就餐问题
算法