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

运行结果


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

相关推荐
huiyunfei41 分钟前
MinorGC FullGC
java·jvm·算法
阿华写代码44 分钟前
重新面试之JVM
jvm·面试·职场和发展
弓.长.1 小时前
【leetcode刷题】:双指针篇(有效三角形的个数、和为s的两个数)
c++·算法·leetcode
生信与遗传解读2 小时前
XGBoost算法在自定义数据集中预测疾病风险
人工智能·python·算法·数据分析
这辈子秃头是不可能的2 小时前
OpenGL利用DDA算法绘制图形,并增加鼠标键盘交互
算法·计算机外设·交互
灵哎惹,凌沃敏3 小时前
华为C语言编程规范总结
c语言·开发语言
Luo_LA4 小时前
【LeetCode Hot100 贪心算法】 买卖股票的最佳时机、跳跃游戏、划分字母区间
leetcode·游戏·贪心算法
王子良.4 小时前
大数据生态系统:Hadoop(HDFS)、Hive、Spark、Flink、Kafka、Redis、ECharts、Zookeeper之间的关系详解
大数据·hive·hadoop·经验分享·学习·hdfs·spark
疯狂飙车的蜗牛4 小时前
工作生活的感悟
嵌入式硬件·程序人生·职场和发展·感悟
范纹杉想快点毕业5 小时前
XML通过HTTP POST 请求发送到指定的 API 地址,进行数据回传
xml·c语言·开发语言·数据结构·c++·python·c#