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

生日祝福网页源码html哈尔滨seo推广优化

生日祝福网页源码html,哈尔滨seo推广优化,新手做网站的详细步骤,阿坝州做网站公司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.hrbkazy.com/news/42573.html

相关文章:

  • 贾汪区住房和城乡建设局网站百度自动点击器怎么用
  • 晋江网站建设企业河南网络推广那家好
  • wordpress 调用热门文章宁波正规优化seo公司
  • wordpress可以做下载长沙网站优化价格
  • wordpress站点实例百度百度
  • 傻瓜式做网站哪个软件好百度seo快速
  • 行业网站建设报价厨师培训
  • 做红包网站是犯法的吗推广活动策划方案范文
  • wordpress 个性插件鹤壁seo
  • 学广告设计前景怎么样seo优化网站教程百度
  • 天天向上做图网站搜索 引擎优化
  • div+css网站模版下载百度搜索推广收费标准
  • 长辛店镇网站建设信息流优化师是干什么的
  • o2o网站建设公司优化网站的软件下载
  • 怎么让百度蜘蛛围着网站爬取广告推广
  • 网站规划与建设重要性理解与体会谷歌竞价广告
  • 私人做医院的网站google广告
  • 网站网站制作网站维护是做什么的
  • 宝鸡企业网站建设长春网站优化
  • 社交网站百度公司官网招聘
  • 网站开发基础班内容有哪些b站推广渠道
  • 网页设计图片素材关于设计郑州百度搜索优化
  • 高端外贸网站制作上海seo优化公司kinglink
  • 如何做tiktok的数据排行网站搜索引擎技术
  • 绍兴网站推广今日十大热点新闻
  • 视频上传下载网站建设百度推广登录网站
  • 进空间的网站上海网站建设方案
  • 成都网站建设司百度关键词搜索查询
  • 深圳网站设计营销型网站制作的基本流程是什么
  • 阳江营销型网站建设广州网站建设公司