【leetcode|哈希表、动态规划】最长连续序列、最大子数组和

news/2024/10/23 2:48:54/

目录

最长连续序列

解法一:暴力枚举

复杂度

解法二:优化解法一省去二层循环中不必要的遍历

复杂度

最大子数组和

解法一:暴力枚举

复杂度

解法二:贪心

复杂度

解法三:动态规划

复杂度


最长连续序列

输入输出示例:

解法一:暴力枚举

两层循环,第一层循环是遍历整个数组;第二层循环的目的是得到最长连续序列时间复杂度极高,效率低下。

1、如果不使用哈希表在枚举过程中查找nums[i]+1时要通过遍历整个数组来进行,因此时间复杂度是O(n^2)

2、使用哈希表枚在举过程中虽说哈希表查找数据的时间复杂度是O(1),但第二次循环仍然需要执行多次,最坏的情况下其时间复杂度也会接近O(n^2)

class Solution {
public:int longestConsecutive(vector<int>& nums) {if(0 == nums.size()) //注意:需要考虑nums为空的情况,此时的最长连续序列就是0return 0;unordered_set<int> hashtable;int max_length = INT_MIN;for(const auto& e:nums) //使用哈希表去重数据hashtable.emplace(e);for(const auto& e:hashtable){int tmp = e;int cnt = 1;while(hashtable.count(++tmp))++cnt;max_length = std::max(max_length,cnt);}return max_length;}
};

复杂度

时间复杂度: O(n^2)

空间复杂度:O(n)

解法二:优化解法一省去二层循环中不必要的遍历

class Solution {
public:int longestConsecutive(vector<int>& nums) {if(0 == nums.size())return 0;int size = nums.size();int max_length = 0;unordered_set<int> hashtable;for(const auto& e:nums)hashtable.insert(e);for(const auto& e:hashtable){if(!hashtable.count(e-1))//只在哈希表中找连续序列的第一个数{int cnt = 1;int tmp = e;while(hashtable.count(++tmp))++cnt;max_length = std::max(max_length,cnt);}}return max_length;}
};

复杂度

时间复杂度:O(n)

空间复杂度:O(n)

最大子数组和

输入输出示例

解法一:暴力枚举

两层循环,定义一个max_sum变量,第二层循环中定义一个tmp变量用来记录第二层循环中连续子数组的和。

lass Solution {
public:int maxSubArray(vector<int>& nums) {int size = nums.size();int max_sum = INT_MIN;for(int i = 0;i<size;++i){int tmp = 0; //用来记录连续子数组的和for(int j = i;j<size;++j){tmp += nums[j];max_sum = std::max(max_sum,tmp);}}return max_sum;}
};

该暴力枚举会超出时间限制,不适合。

复杂度

时间复杂度:O(n^2)

空间复杂度:O(1)

解法二:贪心

class Solution {
public:int maxSubArray(vector<int>& nums) {int size = nums.size();int max_sum = nums[0]; //考虑到数组nums只有一个元素的时候,加上题目限制:子数组中至少包含一个元素int tmp = nums[0];for(int i = 1;i<size;++i){if(tmp > 0)tmp += nums[i];elsetmp = nums[i];max_sum = std::max(max_sum,tmp);}return max_sum;}
};

复杂度

时间复杂度:O(n)

空间复杂度:O(1)

解法三:动态规划

定义一个dp数组,dp[i]表示以 i 位置结尾的子数组的最大和,利用已经有的dp[i-1]值求dp[i]。

class Solution {
public:int maxSubArray(vector<int>& nums) {int size = nums.size();vector<int> dp(size);//dp[i]表示以i位置结尾的连续子数组的最大和dp[0] = nums[0];int max_sum = dp[0];//当size == 1的时候程序不进入下面循环,直接返回nums[0]for(int i = 1;i<size;++i){if(dp[i-1]>0)dp[i] = dp[i-1] + nums[i];elsedp[i] = nums[i];max_sum = std::max(max_sum,dp[i]);}return max_sum;}
};

复杂度

时间复杂度:O(n)

空间复杂度:O(n)

使用滚动数组将空间复杂度优化为O(1):

class Solution {
public:int maxSubArray(vector<int>& nums) {int size = nums.size();//vector<int> dp(size);//dp[i]表示以i位置结尾的连续子数组的最大和int dp1 = nums[0];int dp2 = 0;int max_sum = dp1;for(int i = 1;i<size;++i){if((dp1+nums[i]) > nums[i])dp2 = dp1 + nums[i];elsedp2 = nums[i];max_sum = std::max(max_sum,dp2);dp1 = dp2;//更新dp1}return max_sum;}
};

http://www.ppmy.cn/news/1541218.html

相关文章

【Linux】-权限

&#x1f511;&#x1f511;博客主页&#xff1a;阿客不是客 &#x1f353;&#x1f353;系列专栏&#xff1a;深入代码世界&#xff0c;了解掌握 Linux 欢迎来到泊舟小课堂 &#x1f618;博客制作不易欢迎各位&#x1f44d;点赞⭐收藏➕关注 ​ 一、权限的概念 在Linux 中&…

npm 中的 package.json 实践

package.json 是现在前端项目必备的文件&#xff0c;涵盖了项目依赖、项目命令、项目信息等内容。下面是一个 package.json 常有的样子。 {"name": "my_package","version": "1.0.1","description": "make your packa…

【C++】创建TCP客户端

目录 一、实现发送字符串功能 二、实现接收字符串功能 三、客户端接收乱码问题 四、客户端发送乱码问题 五、客户端接收到数据时进行回调 六、子线程接收数据 七、发送Json格式数据 源码 一、实现发送字符串功能 头文件 #pragma once #include <iostream> #inc…

使用pyqt创建一个移动的矩形

使用pyqt创建一个移动的矩形 程序功能概述效果详细代码 程序功能概述 程序的主要功能是在一个窗口内绘制一个矩形框&#xff0c;并使这个矩形框能够以固定的速度向右移动。当矩形框移动出窗口右侧边界时&#xff0c;它会重新出现在窗口的左侧。 效果 详细代码 import sys fr…

【C++】— 一篇文章让你认识STL

文章目录 &#x1f335;1.什么是STL&#xff1f;&#x1f335;2.STL的版本&#x1f335;3.STL的六大组件&#x1f335;4.STL的重要性&#x1f335;5. 如何学习STL&#x1f335;6. 学习STL的三种境界 &#x1f335;1.什么是STL&#xff1f; STL是Standard Template Library的简称…

Leetcode - 周赛419

目录 一&#xff0c;3318. 计算子数组的 x-sum I 二&#xff0c;3319. 第 K 大的完美二叉子树的大小 三&#xff0c;3320. 统计能获胜的出招序列数 四&#xff0c;3321. 计算子数组的 x-sum II 一&#xff0c;3318. 计算子数组的 x-sum I 本题数据范围较小&#xff0c;可以…

iOS18 TabbarController 切换动画

升级 iOS18后&#xff0c; TabbarController 切换会带有一个缩放动画&#xff0c;下面是自定义取消动画的代码 #import "TabBarVC.h"interface TabBarVC () <UIViewControllerAnimatedTransitioning, UITabBarControllerDelegate>endimplementation TabBarVC-…

代码训练营 day42|LeetCode 518,LeetCode 377,LeetCode 70

前言 这里记录一下陈菜菜的刷题记录&#xff0c;主要应对25秋招、春招 个人背景 211CS本CUHK计算机相关硕&#xff0c;一年车企软件开发经验 代码能力&#xff1a;有待提高 常用语言&#xff1a;C 系列文章目录 第42天 &#xff1a;第九章 动态规划 part05 文章目录 前言系…