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;
}

运行结果


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

相关推荐
10001hours1 小时前
初阶数据结构.1.顺序表.通讯录项目(只有源码和注释)
数据结构·算法
GilgameshJSS1 小时前
STM32H743-ARM例程33-TOUCH
c语言·arm开发·stm32·单片机·嵌入式硬件
Emilia486.3 小时前
八大排序算法
算法·排序算法
blammmp3 小时前
算法专题十九:记忆化搜索(暴搜->记忆化搜索)
算法·深度优先·记忆化搜索
纵有疾風起3 小时前
C++—string(1):string类的学习与使用
开发语言·c++·经验分享·学习·开源·1024程序员节
MicroTech20253 小时前
边缘智能的创新:MLGO微算法科技推出基于QoS感知的边缘大模型自适应拆分推理编排技术
科技·算法·ai
luoqice3 小时前
如何编译QT可执行release程序
c语言
王哈哈^_^5 小时前
【数据集】【YOLO】目标检测游泳数据集 4481 张,溺水数据集,YOLO河道、海滩游泳识别算法实战训练教程。
人工智能·算法·yolo·目标检测·计算机视觉·分类·视觉检测
巴里巴气5 小时前
第73题 矩阵置零
线性代数·算法·矩阵
007php0075 小时前
某游戏大厂 Java 面试题深度解析(四)
java·开发语言·python·面试·职场和发展·golang·php