每日两道力扣,day2

每日两道力扣,day2

每日两道力扣,day2

每日两道力扣,今日是:

162. 寻找峰值 - 力扣(LeetCode)

153. 寻找旋转排序数组中的最小值 - 力扣(LeetCode)

第一题:寻找峰值

162. 寻找峰值 - 力扣(LeetCode)

1.思路:

首先,看到这题第一眼我的脑海里浮现的是直接遍历数组查找max,时间复杂度O(n),但题目规定必须使用时间复杂度为O(log n)的算法,所以我们只能另求他路。

尽管根据测试数据我们并不能看出数组是有序的,但这个题又说 "给你一个整数数组 nums,找到峰值元素并返回其索引。数组可能包含多个峰值,在这种情况下,返回 任何一个峰值 所在位置即可。"

而且 根据昨天的852. 山脉数组的峰顶索引 - 力扣(LeetCode)

我们可以发现山脉数组的峰顶索引其实上是这个题的子集,既然如此那就容易了,同样用二分查找即可解决。

按照二分查找的思路我们可以把arr分为两段,一段是递增的(也就是arrmid < arrmid + 1),一段是递减的(也就是arrmid > arrmid + 1),而这两段的链接点就是我们要找的峰顶(当left与right相遇时),按照这个逻辑,我们总能找到峰值。

2.代码实现:

复制代码
class Solution {
public:
    int findPeakElement(vector<int>& nums) {
      int left = 0, right = nums.size() - 1;

      while(left < right)
      {
        int mid = left + (right - left)/2;
        if(nums[mid] > nums[mid+1])
        right = mid;
        else if(nums[mid] < nums[mid+1])
        left = mid + 1;

      } 
      return left; 
    }
};

3.细节:

所以我们得采用 int mid = left + (right - left)/2; 来防止数据溢出

第二题:寻找旋转排序数组中的最小值

153. 寻找旋转排序数组中的最小值 - 力扣(LeetCode)


1.思路:

首先,看到这题第一眼我的脑海里浮现的是直接遍历数组查找min,时间复杂度O(n),但题目规定必须使用时间复杂度为O(log n)的算法,所以我们只能另求他路。

思路图如下:

以上是根据测试用例模拟出来的草图,示例一,二如上图。示例三为上图的最左端那段上升的射线。

核心思路:

想象一下你在爬坡。将 mid 与右边界 right 进行比较

(1)如果numsmid > numsright,mid 在左侧的高斜坡,最小值肯定在右边,left = mid + 1。让mid往右走一点

(2)反之numsmid < numsright,mid 在右侧的低斜坡,最小值在 mid 或者是 mid 的左边,right = mid。让mid往左走一点。

(3)循环结束时,left 和 right 相遇,指向的就是最小值

2.代码实现:
复制代码
class Solution {
public:
    int findMin(vector<int>& nums) {
        int left = 0, right = nums.size() - 1;

        while(left < right) {
            int mid = left + (right - left) / 2;
            
            // 核心思路:将 mid 与右边界 right 进行比较
            if(nums[mid] > nums[right]) {
                // mid 在左侧的高斜坡,最小值肯定在右边
                left = mid + 1;
            } else {
                // mid 在右侧的低斜坡,最小值在 mid 或者是 mid 的左边
                right = mid;
            }
        }
        
        // 循环结束时,left 和 right 相遇,指向的就是最小值
        return nums[left];
    }
};
3.细节:

我们得采用 int mid = left + (right - left)/2; 来防止数据溢出

好了,今天的每日两道力扣到这里就算是结束了,看完是不是感觉有所收获呢?如果学有所获的话,麻烦给个三连支持一下呗。感谢观看,您的支持,将是我前进路上的重要动力。

相关推荐
8Qi88 小时前
LeetCode 75:颜色分类(荷兰国旗问题)—— Java 题解 ✅
java·算法·leetcode·指针·排序
888CC++9 小时前
如何在 C 语言中进行程序调试?
前端·javascript·算法
(●—●)橘子……11 小时前
力扣第503场周赛练习理解
python·学习·算法·leetcode·职场和发展·周赛
明志数科12 小时前
4D时序标注技术详解:让机器人理解连续动作的数据基础
java·算法·机器人
feng_you_ying_li13 小时前
C++复习二,继承与多态
c++
小小de风呀13 小时前
de风——【从零开始学C++】(十一):list的基本使用和模拟实现
开发语言·c++·list
KaMeidebaby13 小时前
卡梅德生物技术快报|原核表达系统工艺优化:包涵体重折叠 + 分子筛纯化实现功能 RBD 高效制备,附全参数配置
前端·人工智能·算法·数据挖掘·数据分析
陌路2013 小时前
C++高级进阶--夯实进阶基础(1)
开发语言·c++
无限码力13 小时前
携程0510笔试真题【单数组交换】
算法·携程笔试·携程笔试真题·携程0510笔试真题