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

wordpress 小熊资源网长沙官网seo技巧

wordpress 小熊资源网,长沙官网seo技巧,b2b的跨境电商平台有哪些,注册一家公司的费用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.khdw.cn/news/17364.html

相关文章:

  • 车牌照丢失能在网站做吗长尾关键词挖掘工具爱网站
  • 网站怎样做银联支付网络营销策略制定
  • 软件下载网站如何履行安全管理义务一个平台怎么推广
  • 平台电商运营seo综合查询系统
  • 苏州网站建设系统价格合理seo如何快速出排名
  • 怎样建设网站客服服务器关键词优化seo
  • 分析网站的外链seo资料
  • 网站平台在线提交功能seort什么意思
  • wordpress前台403seo咨询顾问
  • 网站设计收费模式网站管理与维护
  • 欧美风格网站源码近期新闻事件
  • 重庆招投标综合信息网企业网站优化公司
  • 织梦网站访问量统计代码武汉seo公司哪家专业
  • 服务器做网站用什么环境好搜索引擎大全排行榜
  • 合肥市网站建设怎么弄一个自己的网站
  • 今天体育新闻网站seo哪家好
  • 直销返利网站建设如何建立网址
  • 专业做俄语网站建设百度可以发布广告吗
  • 设计师网站 pins百度关键字
  • 做儿童文学的网站b2b网站推广优化
  • 网站建设哪个公司好知乎营销推广
  • 个人公众号如何开通百度 seo 工具
  • 安徽建设通网站seo知名公司
  • 壶关网站建设seo引擎搜索网址
  • 马鞍山做网站steam交易链接怎么改
  • 大连做网站的企业工程建设数字化管理平台
  • 国建设银行e路通网站申2023半夜免费b站推广
  • 通化网站建设公司牛排seo系统
  • wordpress dux1.2seo自学教程推荐
  • 推广计划方案模板优化什么意思