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

给娃娃做衣服卖的网站樱桃bt官网

给娃娃做衣服卖的网站,樱桃bt官网,北京科兴中维新冠疫苗最新消息,高明网站设计公司最大子数组和 思路: 1.经验题目要求 dp[i]表示:以 i 位置为结尾的所有子数组中的最大和 2.状态转移方程 按长度来划分,如果长度为1,那么dp[i] nums[i]; 如果长度大于1,那么当前位置的最大和就为 i-1 位置最大和 …

最大子数组和

在这里插入图片描述
思路:

1.经验+题目要求

dp[i]表示:以 i 位置为结尾的所有子数组中的最大和

2.状态转移方程

按长度来划分,如果长度为1,那么dp[i] = nums[i];
如果长度大于1,那么当前位置的最大和就为 i-1 位置最大和 + 当前位置,dp[i] = dp[i-1] + nums[i];

然后每一次都要取他们两个中的最大值。

在这里插入图片描述

存在 dp[i-1] , 建表时候多建一格,dp[0]位置为0 就不影响后面的填表
在这里插入图片描述

4 .
从左往右填表。

class Solution {
public:int maxSubArray(vector<int>& nums) {int n = nums.size();vector<int> dp(n+1);int ret = INT_MIN;//为了不影响比较for(int i = 1 ; i<=n; i++){dp[i] = max(nums[i-1],dp[i-1]+nums[i-1]);ret = max(dp[i],ret);//找出dp表里面的最大值}return ret;}
};

环形子数组的最大和

在这里插入图片描述
思路:

区别于上一道题,这一题变成了环形,也就是多了两边的情况,而两边的情况很复杂,我们可不可以把两边问题换为两种上一道题思路的简单问题?

在这里插入图片描述
最大数组和只有两种情况,看 1 在里面的情况,这就跟上一道题一样
看 2 ,当最大数组和在两边的时候,我们可以求出最小数组和的情况,然后sum - min。

步骤及思路都跟上一题一样,无非变成了求一个最大和表和一个最小和表,然后比较max(最大和,sum-最小和);

但是对于返回值,有点变化:
在这里插入图片描述
对于[-2 , -3 , -1], 最大和为-1, 但是最小和为-2 + -3 + -1 ,和sum是一样的,这时候最小和就变为了错误的0;
所以对于返回值要处理, 最小和 == sum的时候,返回最大和,不然返回max(最大和,sum-最小和)。

class Solution {
public:int maxSubarraySumCircular(vector<int>& nums) {int n = nums.size();vector<int> f(n+1);//建表auto g = f;int ret1 = INT_MIN;//不影响比较int ret2 = INT_MAX;int num = 0;for(int i = 1; i<=n; i++){f[i] = max(nums[i-1],f[i-1]+nums[i-1]);ret1 = max(ret1,f[i]);g[i] = min(nums[i-1],g[i-1]+nums[i-1]);ret2 = min(ret2,g[i]);num+=nums[i-1]; //求nums和}return num == ret2 ? ret1 : max(ret1,num - ret2);}
};

乘积最大子数组

在这里插入图片描述
思路:

1.经验+题目要求

dp[i]表示:以 i 位置为结尾的所有子数组中的最大乘积

2.状态转移方程

按长度来划分,如果长度为1,那么dp[i] = nums[i];
如果长度大于1,那么当前位置的最大和就为 i-1 位置最大和 + 当前位置,dp[i] = dp[i-1] * nums[i];

但是因为有正负,前面可能还是乘积最大,后一个数为负数,一下就变成了乘积最小;
相反,前面乘积最小,后一个数为负数,一下就就变成了乘积最大。

所以也要建一个乘积最小表。

在这里插入图片描述
f 表是乘积最大表,g 表是乘积最小表,
对于 f 表来讲,如果长度为1,f[i] = nums[i];
如果长度大于1,但是下一个数大于0,那么f[i] = f[i-1] * nums[i];
如果长度大于1,但是下一个数小于0,那么f[i] = g[i-1] * nums[i];
比较这三者的最大值并填入 f 表即可。 g表同理。

在这里插入图片描述
为了不影响乘积之间的填表,初始化f[0] = g[0] = 1就可以。

4.从左往右,两个表一起填写。

class Solution {
public:int maxProduct(vector<int>& nums) {int n = nums.size();vector<int> f(n+1);auto g = f;int ret1 = INT_MIN;int ret2 = INT_MAX;f[0] = g[0] = 1;for(int i = 1; i<=n; i++){f[i] = max(nums[i-1],max(f[i-1]*nums[i-1], g[i-1]*nums[i-1]));ret1 = max(f[i],ret1);g[i] = min(nums[i-1],min(g[i-1]*nums[i-1], f[i-1]*nums[i-1]));ret2 = min(g[i],ret2);}return ret1;}
};

乘积为正数的最长子数组长度

在这里插入图片描述
思路:

1.经验+题目要求

dp[i]表示:以 i 位置为结尾的所有子数组中乘积为正数的最长长度。

2.状态转移方程
在这里插入图片描述
首先细分,当长度为1的时候,如果nums[i] > 0 ,则为1;
当长度为1的时候,如果nums[i] < 0 ,则为0;
当长度大于1的时候,如果nums[i] > 0 ,则为f[i-1] + 1;
当长度大于1的时候,如果nums[i] < 0 ,则为g[i-1] + 1;但是这个g[i-1] + 1真的对吗?当g[i-1] 为0的时候,也就是前面乘积为正数,乘完nums[i] 后长度就变成0了,但是g[i-1] + 1结果为1,明显是错误的,所以应该判断 g[i-1] == 0 ? 0 : g[i-1] + 1;

再次划分情况,对于nums[i] > 0 的情况,f[i-1] + 1最次也为1,占主导;
对于nums[i] < 0 的情况,g[i-1] == 0 ? 0 : g[i-1] + 1;最次也为0,占主导;
就可以总结为下面那两种占主导的情况。

g[i] 也是如此。
在这里插入图片描述
3.
因为题目问的是长度,初始化f[0] = g[0] = 0;
在这里插入图片描述
4.从左往右,两个表一起填写。

class Solution {
public:int getMaxLen(vector<int>& nums) {int n = nums.size();vector<int> f(n+1);auto g = f;int ret = INT_MIN;for(int i =1; i<=n; i++){if(nums[i-1] > 0){f[i] = f[i-1]+1;g[i] = g[i-1] == 0 ? 0 : g[i-1]+1;}else if(nums[i-1] < 0){f[i] = g[i-1] == 0 ? 0 : g[i-1]+1;g[i] = f[i-1]+1;}ret = max(ret,f[i]);}return ret;}
};
http://www.hkea.cn/news/160076/

相关文章:

  • 网站开发属于什么职位类别seo查询站长工具
  • wordpress postmetaseoul national university
  • 商务网站的主要存在形式杭州百度快照优化公司
  • 个人备案网站做购物网站可以不班级优化大师免费下载电脑版
  • 贸易网站建设互联网广告代理加盟
  • 深圳网站建设网络公司河北关键词排名推广
  • 在工商网上怎么注册公司seo优化博客
  • 免费的小程序怎么赚钱历下区百度seo
  • 河北石家庄最新疫情最新消息优化防疫政策
  • 一站式做网站哪家强新闻小学生摘抄
  • 江西南昌网站建设公司哪家好谷歌google 官网下载
  • 公司网站用什么开发百度指数怎么用
  • 建站主机 wordpress济南网站万词优化
  • 哈尔滨app开发seo自学网官网
  • 网站答辩ppt怎么做全网关键词云在哪里看
  • 网站建设 视频seo关键词词库
  • 网站应用软件设计成都网站建设技术外包
  • 用哪个软件做网站网址查询域名解析
  • 网站安全优化域名停靠浏览器
  • 我做中医培训去哪个网站找学员谷歌排名算法
  • 如何将网站让百度收录网店培训班
  • wordpress旧版页面编辑界面百度seo推广计划类型包括
  • 网站建设茶店网网站换友链平台
  • 珠海建设工程信息网站网络营销百度百科
  • 帮别人做网站推广犯法吗关键词排名网站
  • 建设通网站是政府的么高端网站定制设计
  • 玉溪做网站的公司夸克搜索网页版
  • wordpress导航主题haowseo挂机赚钱
  • 广州做家教的网站深圳网络推广招聘
  • 锐捷网络公司排名seo技术介绍