每日两题 / 53. 最大子数组和 && 56. 合并区间(LeetCode热题100)

53. 最大子数组和 - 力扣(LeetCode)

经典dp题,dp[i]表示以nums[i]为结尾的所有子数组中,最大的和

将i从左到右遍历,考虑dp[i]如何维护?

以nums[i]结尾的子数组只有两种情况,子数组只有nums[i]一个元素、子数组不止nums[i]一个元素

所以dp[i] = max(dp[i - 1] + nums[i], nums[i])

在两种情况中,取最大值即可

cpp 复制代码
class Solution {
public:
    int maxSubArray(vector<int>& nums) {
        vector<int> dp(nums.size());
        dp[0] = nums[0];
        for (int i = 1; i < nums.size(); ++ i)
            dp[i] = max(nums[i], dp[i - 1] + nums[i]);
        int ans = dp[0];
        for (int i = 1; i < dp.size(); ++ i)
            ans = max(ans, dp[i]);
        return ans;
    }
};

56. 合并区间 - 力扣(LeetCode)

按左端点排序,遍历区间,记录一开始的作曲兼并维护最大的右边界

若遇到右边界小于左边界的情况,说明出现不重叠区间,此时维护答案

cpp 复制代码
class Solution {
public:
    vector<vector<int>> merge(vector<vector<int>>& intervals) {
        sort(intervals.begin(), intervals.end(), 
            [&](const vector<int> &left, const vector<int> &right){
                if (left[0] < right[0]) return true;
                else if (left[0] > right[0]) return false;
                else return left[1] < right[1];
        });
        vector<vector<int>> ans;
        int l = intervals[0][0], r = intervals[0][1];
        for (int i = 1; i < intervals.size(); ++ i)
        {
            if (r < intervals[i][0])
            {
                ans.push_back({l, r});
                l = intervals[i][0], r = intervals[i][1];
            }
            else r = max(r, intervals[i][1]);
        }
        ans.push_back({l, r});
        return ans;
    }
};
相关推荐
Q741_1471 小时前
C++ 分治 归并排序 归并排序VS快速排序 力扣 912. 排序数组 题解 每日一题
c++·算法·leetcode·归并排序·分治
victory04311 小时前
K8S 安装 部署 文档
算法·贪心算法·kubernetes
月疯1 小时前
样本熵和泊松指数的计算流程!!!
算法·机器学习·概率论
机器学习之心2 小时前
MATLAB基于自适应动态特征加权的K-means算法
算法·matlab·kmeans
minji...2 小时前
算法题 逆波兰表达式/计算器
数据结构·c++·算法·1024程序员节
编码追梦人3 小时前
基于 STM32 的智能语音唤醒与关键词识别系统设计 —— 从硬件集成到算法实现
stm32·算法·struts
循着风5 小时前
二叉树的多种遍历方式
数据结构·算法
.格子衫.10 小时前
022数据结构之树状数组——算法备赛
数据结构·算法·1024程序员节
黑科技Python10 小时前
生活中的“小智慧”——认识算法
学习·算法·生活
Yupureki10 小时前
从零开始的C++学习生活 16:C++11新特性全解析
c语言·数据结构·c++·学习·visual studio