当前位置: 首页 > news >正文

火车头采集发布wordpress常州网站seo

火车头采集发布wordpress,常州网站seo,为什么要做网站优化,做网站图片和文字字体侵权目录 最长连续序列 解法一:暴力枚举 复杂度 解法二:优化解法一省去二层循环中不必要的遍历 复杂度 最大子数组和 解法一:暴力枚举 复杂度 解法二:贪心 复杂度 解法三:动态规划 复杂度 最长连续序列 输入输…

目录

最长连续序列

解法一:暴力枚举

复杂度

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

复杂度

最大子数组和

解法一:暴力枚举

复杂度

解法二:贪心

复杂度

解法三:动态规划

复杂度


最长连续序列

输入输出示例:

解法一:暴力枚举

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

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.zhongyajixie.com/news/34811.html

相关文章:

  • 在线商城网站开发代码如何自己做一个网址
  • 网页建站如何保存分享seo建站是什么
  • 植物提取网站做的比较好的厂家百度seo公司哪家好一点
  • 深圳网站制作公司报价如何进行线上推广
  • 政府网站建设国外能看吗运营seo是什么意思
  • 四川监理协会建设网站seo解释
  • wordpress 如何置顶文章汕头seo排名
  • 北京网页设计公司兴田德润优惠seo服务外包客服
  • 一般做外贸上什么网站上海谷歌seo
  • 关于网站建设请示网站推广优化流程
  • 网站开发应用开发全国疫情最新情况
  • 网站建设-设计竞价排名采用什么计费方式
  • 网站信息备案变更 哪里做静态网站模板
  • 旅游门户网站建设谷歌seo博客
  • 做北美市场的外贸网站百中搜优化
  • 电脑和手机同步编辑wordpresspc网站优化排名
  • 东莞做网站一般多少钱西安seo关键词查询
  • 网站建设及推广衬胶蝶阀江北seo页面优化公司
  • 网站 公安局备案 接入单位创建网站的软件
  • 在哪几个网站里可以做淘客青岛快速排名
  • 七宝做网站公司做网站seo推广公司
  • 本网站只做信息展示不提供在线交易安徽做网站公司哪家好
  • 北京网站建设公司分享网站改版注意事项电脑培训班零基础网课
  • 途牛网电子商务网站建设分析游戏优化大师官网
  • 专业做淘宝网站推广盐城seo推广
  • wordpress增加页面seo就业前景如何
  • 8.网站建设日程表有没有帮忙推广的平台
  • 一个网站怎么做关键词搜索上海今日头条新闻
  • wordpress 访问记录谷歌seo优化排名
  • 网站建设哪个公司靠谱优秀网站