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

动态规划-子数组系列——乘积最大子数组

1.题目解析

题目来源:152.乘积最大子数组——力扣

测试用例

2.算法原理

1.状态表示

由于题目给的数组中可以包含负数,因此求最大乘积有两种情况:

a.负数乘以最小数得出最大乘积 b.整数乘以最大数得出最大乘积

所以需要两个表分别求出最大最小数,即创建f表存储最大数,g表存储最小数

f[i]:从开始位置到第i个位置的最大子数组乘积

g[i]:从开始位置到第i个位置的最小子数组乘积

2.状态转移方程

f[i]=max(nums[i-1],nums[i-1]*f[i-1],nums[i-1]*g[i-1])

g[i]=min(nums[i-1],nums[i-1]*f[i-1],nums[i-1]*g[i-1])

3.初始化

根据状态转移方程可知每个位置都需要用到前一个位置来进行计算,因此需要初始化两个表的第一个位置,这里更加简单的是使用一个虚拟位置,因为是乘积计算所以将虚拟位置赋值为1不会影响后续填表

4.填表顺序

从前向后,两个表一起填写

5.返回值

返回f表中的最大值即可

3.实战代码

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

 


http://www.mrgr.cn/news/54913.html

相关文章:

  • Python语法基础
  • 使用finalshell远程ssh连接ubuntu
  • PHP中的ReflectionClass常见用法
  • 专家辅助证人出庭质证实务运用之技巧
  • PyMySQL连接MySQL和StarRocks查询表
  • Python 数据类型,是否可变、可哈希
  • 文心一言 VS 讯飞星火 VS chatgpt (373)-- 算法导论24.4 5题
  • SpringBoot3整合RocketMQ问题处理
  • Qt 实战(11)样式表 | 11.2、使用样式表
  • 单元化架构,分布式系统的新王!
  • Java学习教程,从入门到精通, Java 基础语法(4)
  • VMware虚拟机三种网络模式详解
  • 【计网笔记】以太网
  • 深度学习-2:数据向量化
  • python 函数式编程
  • 死锁的具体案例分析
  • 集合框架14:TreeSet概述、TreeSet使用、Comparator接口及举例
  • 基于深度学习的地形分类与变化检测
  • 快速学会一个算法:Faster R-CNN进行目标检测!
  • leetcode day1
  • resnetv1骨干
  • 轮班管理新策略,提高效率与降低员工抱怨
  • Vue3中使用自定义指令实现后台管理系统中对于按钮权限的控制
  • 五年三次冲刺IPO失败,企业业绩成长性恐不足,三年分红约1.5亿元
  • 对比迁移项目的改动
  • 值得收藏学习的人工智能学习框架!