我的编程空间,编程开发者的网络收藏夹
学习永远不晚

C++实现LeetCode(34.在有序数组中查找元素的第一个和最后一个位置)

短信预约 -IT技能 免费直播动态提醒
省份

北京

  • 北京
  • 上海
  • 天津
  • 重庆
  • 河北
  • 山东
  • 辽宁
  • 黑龙江
  • 吉林
  • 甘肃
  • 青海
  • 河南
  • 江苏
  • 湖北
  • 湖南
  • 江西
  • 浙江
  • 广东
  • 云南
  • 福建
  • 海南
  • 山西
  • 四川
  • 陕西
  • 贵州
  • 安徽
  • 广西
  • 内蒙
  • 西藏
  • 新疆
  • 宁夏
  • 兵团
手机号立即预约

请填写图片验证码后获取短信验证码

看不清楚,换张图片

免费获取短信验证码

C++实现LeetCode(34.在有序数组中查找元素的第一个和最后一个位置)

[LeetCode] 34. Find First and Last Position of Element in Sorted Array 在有序数组中查找元素的第一个和最后一个位置

Given an array of integers nums sorted in ascending order, find the starting and ending position of a given target value.

Your algorithm's runtime complexity must be in the order of O(log n).

If the target is not found in the array, return [-1, -1].

Example 1:

Input: nums = [5,7,7,8,8,10], target = 8
Output: [3,4]

Example 2:

Input: nums = [5,7,7,8,8,10], target = 6
Output: [-1,-1]

这道题让我们在一个有序整数数组中寻找相同目标值的起始和结束位置,而且限定了时间复杂度为 O(logn),这是典型的二分查找法的时间复杂度,所以这里也需要用此方法,思路是首先对原数组使用二分查找法,找出其中一个目标值的位置,然后向两边搜索找出起始和结束的位置,代码如下:

解法一:


class Solution {
public:
    vector<int> searchRange(vector<int>& nums, int target) {
        int idx = search(nums, 0, nums.size() - 1, target);
        if (idx == -1) return {-1, -1};
        int left = idx, right = idx;
        while (left > 0 && nums[left - 1] == nums[idx]) --left;
        while (right < nums.size() - 1 && nums[right + 1] == nums[idx]) ++right;
        return {left, right};
    }
    int search(vector<int>& nums, int left, int right, int target) {
        if (left > right) return -1;
        int mid = left + (right - left) / 2;
        if (nums[mid] == target) return mid;
        if (nums[mid] < target) return search(nums, mid + 1, right, target);
        else return search(nums, left, mid - 1, target);
    }
};

可能有些人会觉得上面的算法不是严格意义上的 O(logn) 的算法,因为在最坏的情况下会变成 O(n),比如当数组里的数全是目标值的话,从中间向两边找边界就会一直遍历完整个数组,那么下面来看一种真正意义上的 O(logn) 的算法,使用两次二分查找法,第一次找到左边界,第二次调用找到右边界即可,具体代码如下:

解法二:


class Solution {
public:
    vector<int> searchRange(vector<int>& nums, int target) {
        vector<int> res(2, -1);
        int left = 0, right = nums.size();
        while (left < right) {
            int mid = left + (right - left) / 2;
            if (nums[mid] < target) left = mid + 1;
            else right = mid;
        }
        if (right == nums.size() || nums[right] != target) return res;
        res[0] = right;
        right = nums.size();
        while (left < right) {
            int mid = left + (right - left) / 2;
            if (nums[mid] <= target) left = mid + 1;
            else right = mid;
        }
        res[1] = right - 1;
        return res;
    }
};

其实我们也可以只使用一个二分查找的子函数,来同时查找出第一个和最后一个位置。如何只用查找第一个大于等于目标值的二分函数来查找整个范围呢,这里用到了一个小 trick,首先来查找起始位置的 target,就是在数组中查找第一个大于等于 target 的位置,当返回的位置越界,或者该位置上的值不等于 target 时,表示数组中没有 target,直接返回 {-1, -1} 即可。若查找到了 target 值,则再查找第一个大于等于 target+1 的位置,然后把返回的位置减1,就是 target 的最后一个位置,即便是返回的值越界了,减1后也不会越界,这样就实现了使用一个二分查找函数来解题啦,参见代码如下:

解法三:


class Solution {
public:
    vector<int> searchRange(vector<int>& nums, int target) {
        int start = firstGreaterEqual(nums, target);
        if (start == nums.size() || nums[start] != target) return {-1, -1};
        return {start, firstGreaterEqual(nums, target + 1) - 1};
    }
    int firstGreaterEqual(vector<int>& nums, int target) {
        int left = 0, right = nums.size();
        while (left < right) {
            int mid = left + (right - left) / 2;
            if (nums[mid] < target) left = mid + 1;
            else right = mid;
        }
        return right;
    }
};

到此这篇关于C++实现LeetCode(34.在有序数组中查找元素的第一个和最后一个位置)的文章就介绍到这了,更多相关C++实现在有序数组中查找元素的第一个和最后一个位置内容请搜索编程网以前的文章或继续浏览下面的相关文章希望大家以后多多支持编程网!

免责声明:

① 本站未注明“稿件来源”的信息均来自网络整理。其文字、图片和音视频稿件的所属权归原作者所有。本站收集整理出于非商业性的教育和科研之目的,并不意味着本站赞同其观点或证实其内容的真实性。仅作为临时的测试数据,供内部测试之用。本站并未授权任何人以任何方式主动获取本站任何信息。

② 本站未注明“稿件来源”的临时测试数据将在测试完成后最终做删除处理。有问题或投稿请发送至: 邮箱/279061341@qq.com QQ/279061341

C++实现LeetCode(34.在有序数组中查找元素的第一个和最后一个位置)

下载Word文档到电脑,方便收藏和打印~

下载Word文档

猜你喜欢

C++如何实现在有序数组中查找元素的第一个和最后一个位置

这篇文章主要讲解了“C++如何实现在有序数组中查找元素的第一个和最后一个位置”,文中的讲解内容简单清晰,易于学习与理解,下面请大家跟着小编的思路慢慢深入,一起来研究和学习“C++如何实现在有序数组中查找元素的第一个和最后一个位置”吧!Fin
2023-06-20

C语言如何查找字符串在另一个字符串中最后一次出现的位置

利用C语言的strstr函数,可以查找字符串在目标字符串中的最后一次出现位置。该函数返回第一次出现位置的指针,如果不存在则返回NULL。本教程还介绍了strrchr、strcspn等相关函数,帮助进行字符串处理。
C语言如何查找字符串在另一个字符串中最后一次出现的位置
2024-04-02

C语言如何查找字符串在另一个字符串中最后一次出现的位置,并返回从该位置到字符串结尾的所有字符

详解如何使用C语言strstr函数查找字符串中最后一次出现的子串,并返回子串后续内容。方法是遍历主串,找到子串后计算其长度,然后返回子串在主串中的位置加上长度后的内容。
C语言如何查找字符串在另一个字符串中最后一次出现的位置,并返回从该位置到字符串结尾的所有字符
2024-04-02

PHP如何查找字符串在另一个字符串中最后一次出现的位置,并返回从该位置到字符串结尾的所有字符

本篇文章介绍了PHP中查找字符串最后一次出现的位置的方法,并获取从该位置到字符串结尾的所有字符。使用strrpos()函数确定最后出现的位置,然后用substr()函数获取后续字符。示例代码展示了如何使用这些函数查找并获取子字符串。其他注意事项包括offset参数、空子字符串和子字符串长度超过主字符串的情况。
PHP如何查找字符串在另一个字符串中最后一次出现的位置,并返回从该位置到字符串结尾的所有字符
2024-04-02

Python如何查找字符串在另一个字符串中最后一次出现的位置,并返回从该位置到字符串结尾的所有字符

Python中,可以使用rfind()方法查找字符串在另一个字符串中最后一次出现的位置。要提取从最后出现位置到字符串结尾的字符,使用substringing操作即可。此外,还有in操作符、正则表达式和第三方库等其他方法可供选择。选择哪种方法取决于具体情况的效率和功能需求。
Python如何查找字符串在另一个字符串中最后一次出现的位置,并返回从该位置到字符串结尾的所有字符
2024-04-02

Java如何查找字符串在另一个字符串中最后一次出现的位置,并返回从该位置到字符串结尾的所有字符

本文介绍了在Java中查找字符串在另一个字符串中最后一次出现的位置,并返回从该位置到字符串结尾的所有字符的方法。通过使用lastIndexOf()方法和substrin()方法,可以轻松实现此功能。此外,还提供了替代方法,使用正则表达式来查找字符串的最后一次出现。
Java如何查找字符串在另一个字符串中最后一次出现的位置,并返回从该位置到字符串结尾的所有字符
2024-04-02

Go语言如何查找字符串在另一个字符串中最后一次出现的位置,并返回从该位置到字符串结尾的所有字符

在Go中查找字符串最后一次出现的索引并返回剩余内容。使用strings.LastIndex查找索引,然后通过strings.substr提取剩余内容。其他方法包括正则表达式和循环。代码示例说明了strings.LastIndex和strings.substr的用法。
Go语言如何查找字符串在另一个字符串中最后一次出现的位置,并返回从该位置到字符串结尾的所有字符
2024-04-02

编程热搜

  • Python 学习之路 - Python
    一、安装Python34Windows在Python官网(https://www.python.org/downloads/)下载安装包并安装。Python的默认安装路径是:C:\Python34配置环境变量:【右键计算机】--》【属性】-
    Python 学习之路 - Python
  • chatgpt的中文全称是什么
    chatgpt的中文全称是生成型预训练变换模型。ChatGPT是什么ChatGPT是美国人工智能研究实验室OpenAI开发的一种全新聊天机器人模型,它能够通过学习和理解人类的语言来进行对话,还能根据聊天的上下文进行互动,并协助人类完成一系列
    chatgpt的中文全称是什么
  • C/C++中extern函数使用详解
  • C/C++可变参数的使用
    可变参数的使用方法远远不止以下几种,不过在C,C++中使用可变参数时要小心,在使用printf()等函数时传入的参数个数一定不能比前面的格式化字符串中的’%’符号个数少,否则会产生访问越界,运气不好的话还会导致程序崩溃
    C/C++可变参数的使用
  • css样式文件该放在哪里
  • php中数组下标必须是连续的吗
  • Python 3 教程
    Python 3 教程 Python 的 3.0 版本,常被称为 Python 3000,或简称 Py3k。相对于 Python 的早期版本,这是一个较大的升级。为了不带入过多的累赘,Python 3.0 在设计的时候没有考虑向下兼容。 Python
    Python 3 教程
  • Python pip包管理
    一、前言    在Python中, 安装第三方模块是通过 setuptools 这个工具完成的。 Python有两个封装了 setuptools的包管理工具: easy_install  和  pip , 目前官方推荐使用 pip。    
    Python pip包管理
  • ubuntu如何重新编译内核
  • 改善Java代码之慎用java动态编译

目录