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

运行结果


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

相关推荐
风中的微尘1 小时前
39.网络流入门
开发语言·网络·c++·算法
西红柿维生素2 小时前
JVM相关总结
java·jvm·算法
ChillJavaGuy3 小时前
常见限流算法详解与对比
java·算法·限流算法
sali-tec3 小时前
C# 基于halcon的视觉工作流-章34-环状测量
开发语言·图像处理·算法·计算机视觉·c#
Gu_shiwww4 小时前
数据结构8——双向链表
c语言·数据结构·python·链表·小白初步
程思扬4 小时前
利用JSONCrack与cpolar提升数据可视化及跨团队协作效率
网络·人工智能·经验分享·docker·信息可视化·容器·架构
你怎么知道我是队长5 小时前
C语言---循环结构
c语言·开发语言·算法
艾醒5 小时前
大模型面试题剖析:RAG中的文本分割策略
人工智能·算法
程序猿编码6 小时前
基于 Linux 内核模块的字符设备 FIFO 驱动设计与实现解析(C/C++代码实现)
linux·c语言·c++·内核模块·fifo·字符设备
纪元A梦7 小时前
贪心算法应用:K-Means++初始化详解
算法·贪心算法·kmeans