leetcode(hot100)13-17

解题思路:前缀和 动态规划

主要思路利用前缀和 然后前缀和sum-minsum等于最终的结果 minsum怎么求呢 minsum=min(minsum,sum)

因为sum的前缀和有可能为负值 如果负值的话就取负值如果是正值就取0minsum;

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

解题思路:

首先排序 二维数组排序只排第一列 然后 result.back()[1] = max(result.back()[1],right);right=intervals[i][1],right就是右边界

cpp 复制代码
class Solution {
public:
    vector<vector<int>> merge(vector<vector<int>>& intervals) {
        if(intervals.size() == 0)return {};
        sort(intervals.begin(),intervals.end());
        vector<vector<int>>result;
        for(int i = 0;i<intervals.size();i++){
            int left = intervals[i][0],right = intervals[i][1];
            if(!result.size() || result.back()[1] < left){
                result.push_back({left,right});
            }
            else{
                result.back()[1] = max(result.back()[1],right);
            }
        }
        return result;
    }
};

解题思路:反转

注意本题没有保证 k 小于数组长度 n。由于轮转 n 次等于没有轮转,轮转 n+1 等于轮转 1 次,依此类推,轮转 k 次等于轮转 kmodn 次。

先反转全部,然后在反转前k个 然后在反转后面所有的;

cpp 复制代码
class Solution {
public:
    void rotate(vector<int>& nums, int k) {
        k %= nums.size();
        reverse(nums.begin(),nums.end());
        reverse(nums.begin(),nums.begin()+k);
        reverse(nums.begin()+k,nums.end());

    }
};

解题思路:相当于前后缀分解

把这个自身的左边和右边分为两个部分,然后用两个for循环分别表示左边的成绩和右边的成绩

cpp 复制代码
class Solution {
public:
    vector<int> productExceptSelf(vector<int>& nums) {
        int n = nums.size();
        vector<int>suf(n,1);
        for(int i = n-2;i>=0;i--){
            suf[i] = suf[i+1]*nums[i+1];

        }
        int pre = 1;
        for(int i = 0;i<n;i++){
            suf[i] *= pre;
            pre *= nums[i];
        }
        return suf;
    }
};

解题思路:将数组视为哈希表 我们将所有1到n范围内的数放入哈希表中,也可以得到最终的答案。将数组下标从 0 开始)打上「标记」。

首先将所有的负数都变为n+1 因为n+1肯定不会被找到

然后将所有<n的数变为负数 返回第一个大于0下标+1

cpp 复制代码
class Solution {
public:
    int firstMissingPositive(vector<int>& nums) {
        int n = nums.size();
        for(int i = 0;i< n;i++){
            if(nums[i] <= 0){
                nums[i] = n+1;
            }
        }
        for(int i = 0;i<n;i++){
            int num = abs(nums[i]);
            if(num <= n){
                nums[num-1] = -abs(nums[num-1]);
            }
        }
        for(int i = 0;i<n;i++){
            if(nums[i]>0){
                return i+1;
            }
        }
        return n+1;
    }
};
相关推荐
q***51891 小时前
【语义分割】12个主流算法架构介绍、数据集推荐、总结、挑战和未来发展
算法·架构
Ghost-Silver2 小时前
《星火》——关于Deepseek的进化速度
笔记·算法
代码游侠5 小时前
日历的各种C语言实现方法
c语言·开发语言·学习·算法
春日见9 小时前
丝滑快速拓展随机树 S-RRT(Smoothly RRT)算法核心原理与完整流程
人工智能·算法·机器学习·路径规划算法·s-rrt
Code小翊9 小时前
”回调“高级
算法·青少年编程
云里雾里!9 小时前
力扣 977. 有序数组的平方:双指针法的优雅解法
算法·leetcode·职场和发展
一只侯子12 小时前
Face AE Tuning
图像处理·笔记·学习·算法·计算机视觉
jianqiang.xue12 小时前
别把 Scratch 当 “动画玩具”!图形化编程是算法思维的最佳启蒙
人工智能·算法·青少年编程·机器人·少儿编程
不许哈哈哈12 小时前
Python数据结构
数据结构·算法·排序算法
J***793913 小时前
后端在分布式系统中的数据分片
算法·哈希算法