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

青海网站设计企业开网站空间流量怎么选择

青海网站设计企业,开网站空间流量怎么选择,九江做网站的公司,烟台优化网站公司1.题目解析 题目来源:1567.乘积为正数的最长子数组——力扣 测试用例 2.算法原理 1.状态表示 因为数组中存在正数与负数,如果求乘积为正数的最长子数组,那么存在两种情况使得乘积为正数,第一种就是正数乘以正数,第…

1.题目解析 

题目来源:1567.乘积为正数的最长子数组——力扣 

测试用例 

2.算法原理

1.状态表示

因为数组中存在正数与负数,如果求乘积为正数的最长子数组,那么存在两种情况使得乘积为正数,第一种就是正数乘以正数,第二种就是负数乘以负数,那么就必须使用两个表来分别存储这两种情况,其中f表存储乘积为正数的子数组最长长度,g表存储乘积为负数的子数组最长长度

f[i]:以第i个位置为结尾的乘积为正数的子数组最长长度

g[i]:以第i个位置为结尾的乘积为负数的子数组最长长度

2.状态转移方程

当遇到的为正数,此时填两个表需要分别用到自己表的前一个位置的值,也就是

f[i]=f[i-1]+1;g[i]=g[i-1]==0?0:g[i-1]+1;这里特殊处理g表是因为当第i个位置之前乘积全为正数时g[i-1]=0,如果此时直接g[i]=g[i-1]+1则不符合实际情况

当遇到的为负数,此时填两个表需要用到对方表内的前一个位置的值,也就是

f[i]=g[i-1]==0?0:g[i-1]+1;g[i]=f[i-1]+1;这里以及特殊处理g[i-1]避免错误

3.初始化

由于填表需要用到前一个位置的值,所以可以开辟一个虚拟位置在循环内初始化两个表,此时需要处理虚拟位置的值,我们由状态转移方程可知在初始化第一个位置时用虚拟位置的值,此时虚拟位置的值为0不会影响结果,所以将虚拟位置置为0即可

4.填表顺序

从左到右,两个表一起填写

5.返回值

返回f表的最大值即可

3.实战代码

class Solution {
public:int getMaxLen(vector<int>& nums) {int n = nums.size();vector<int> f(n+1);vector<int> g(n+1);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;}if(nums[i-1] < 0){f[i] = g[i-1] == 0 ? 0 : g[i-1] + 1;g[i] = f[i-1] + 1;}ret = max(f[i],ret);}    return ret;}
};
http://www.yayakq.cn/news/956042/

相关文章:

  • 企顺网网站建设程序代码优化网站
  • 网站设置成灰色网站建设 书籍
  • cdr做网站怎么导出在线排版设计
  • 网站源码路径怎么在建设银行网站留言
  • 夹江移动网站建设做网站是怎么挣钱的
  • 太原网站优化技术网页设计公司网易企业邮箱
  • 建站网站怎么上传代码外贸业务员如何寻找国外客户
  • 宝德科技专业嘉兴网站建设wordpress添加单页模板
  • 腾讯域名注册网站九江有没有做网站的公司
  • 安徽建新建设工程有限公司网站wordpress 图文插件
  • 网站建设主要学什么软件用python做的网站
  • 网站开发接外包wordpress清理
  • 重庆森林电影佛山网站建设优化
  • 学做软件的网站百度推广获客
  • 30岁转行做网站编辑自助建站申请书
  • 襄县网站建设做服装网站
  • 网站 icp备案在线制作离婚证图片
  • qwins是哪个网站做的网站服务器vps
  • 安阳网站建设优化北京果木烤鸭制作方法
  • 网站开发产品经理成都市建设厅网站
  • 一个好的网站应该具有什么条件电子商务网站页面设计图片
  • 中国做铁塔的公司网站Wordpress query 参数
  • dream网站怎么做框架wordpress 多语言版本
  • 广东网站搭建网页设计与制作实训报告2000字
  • 美食网站是怎么做的网站怎么做移动图片不显示
  • o2o网站制作公司宁波市建设局
  • 大型建站网站wordpress评测网站
  • 新乡建设网站wordpress cdn推荐
  • 网站一般多少钱一年创建购物网站多少钱
  • 南京 网站设计腾讯企业邮箱登录入口网址