152. Maximum Product Subarray - LeetCode
Question

Solution
题目大意:求数列中连续子序列的最大连乘积
思路:动态规划实现,现在动态规划理解的还不透,照着公式往上套的,这个问题要注意正负,需要维护两个结果
Java实现:
public int maxProduct(int[] nums) {
    if (nums.length == 1) return nums[0];
    // 定义问题:状态及对状态的定义
    // 设max[i]表示数列中第i项结尾的连续子序列的最大连乘积
    // 求max[0]...max[n]中的最大值
    // 状态转移方程
    // max[0] = nums[0]
    // max[i] = Max.max(max[i-1] * nums[i], nums[i])
    int[] max = new int[nums.length];
    int[] min = new int[nums.length];
    for (int i = 0; i < nums.length; i++) {
        max[i] = min[i] = nums[i];
    }
    int product = nums[0];
    for (int i = 1; i < nums.length; i++) {
        if (nums[i] < 0) {
            max[i] = Math.max(min[i - 1] * nums[i], max[i]);
            min[i] = Math.min(max[i - 1] * nums[i], min[i]);
            product = Math.max(max[i], product);
        } else {
            max[i] = Math.max(max[i - 1] * nums[i], max[i]);
            min[i] = Math.min(min[i - 1] * nums[i], min[i]);
            product = Math.max(max[i], product);
        }
    }
    return product;
}
int maxProduct(int A[], int n) {
    // store the result that is the max we have found so far
    int r = A[0];
    // imax/imin stores the max/min product of
    // subarray that ends with the current number A[i]
    for (int i = 1, imax = r, imin = r; i < n; i++) {
        // multiplied by a negative makes big number smaller, small number bigger
        // so we redefine the extremums by swapping them
        if (A[i] < 0)
            swap(imax, imin);
        // max/min product for the current number is either the current number itself
        // or the max/min by the previous number times the current one
        imax = max(A[i], imax * A[i]);
        imin = min(A[i], imin * A[i]);
        // the newly computed max value is a candidate for our global result
        r = max(r, imax);
    }
    return r;
}
关于动态规划

Ref
152. Maximum Product Subarray - LeetCode的更多相关文章
- leetcode 53. Maximum Subarray 、152. Maximum Product Subarray
		53. Maximum Subarray 之前的值小于0就不加了.dp[i]表示以i结尾当前的最大和,所以需要用一个变量保存最大值. 动态规划的方法: class Solution { public: ... 
- 求连续最大子序列积 - leetcode. 152 Maximum Product Subarray
		题目链接:Maximum Product Subarray solutions同步在github 题目很简单,给一个数组,求一个连续的子数组,使得数组元素之积最大.这是求连续最大子序列和的加强版,我们 ... 
- 【刷题-LeetCode】152 Maximum Product Subarray
		Maximum Product Subarray Given an integer array nums, find the contiguous subarray within an array ( ... 
- [LeetCode] 152. Maximum Product Subarray 求最大子数组乘积
		Given an integer array nums, find the contiguous subarray within an array (containing at least one n ... 
- LeetCode 152. Maximum Product Subarray (最大乘积子数组)
		Find the contiguous subarray within an array (containing at least one number) which has the largest ... 
- [LeetCode]152. Maximum Product Subarray
		This a task that asks u to compute the maximum product from a continue subarray. However, you need t ... 
- Maximum Product Subarray——LeetCode
		Find the contiguous subarray within an array (containing at least one number) which has the largest ... 
- 【LeetCode】152. Maximum Product Subarray 解题报告(Python & C++)
		作者: 负雪明烛 id: fuxuemingzhu 个人博客: http://fuxuemingzhu.cn/ 目录 题目描述 题目大意 解题方法 双重循环 动态规划 参考资料 日期 题目地址:htt ... 
- Java for LeetCode 152 Maximum Product Subarray
		Find the contiguous subarray within an array (containing at least one number) which has the largest ... 
随机推荐
- ADAS最全整理
			为了实现「无人驾驶」的理想,各大整车厂和供应商目前正在开发「高级驾驶员辅助系统」(ADAS),随着 ADAS 慢慢被完善,车辆也在一步一步从 NHTSa 的 0 级过度到第 4 级,实现完全自动化.& ... 
- W3School 教程整理
			离线版大部分整理自 w3cschool ,少部分整理自 w3school ,由本人整理. 感谢 w3cschool 站长的无私奉献. 由于本人精力有限,此处的列表不一定能够及时更新,最新版本请到本人博 ... 
- Mpvue 小程序转 Web 实践总结
			介绍 Mpvue 是一个使用 Vue.js 开发小程序的前端框架.框架基于 Vue.js 核心,修改了 Vue.js 的 runtime 和 compiler 实现,使其可以运行在小程序环境中,从而为 ... 
- jq移动端图片预览 (fly-zomm-img.js)
			效果图: ===>==> 里面还与很多属性设置: index 关闭按钮等等 代码: //html-----------------------<div class="he ... 
- Python入门-正则表达式
			正则匹配函数 # 需要先导入re模块 import re #字符串,匹配查找 info = "www baidu com" print("=======字符串自带find ... 
- LC-977
			给你一个按 非递减顺序 排序的整数数组 nums,返回 每个数字的平方 组成的新数组,要求也按 非递减顺序 排序. 示例 1: 输入:nums = [-4,-1,0,3,10] 输出:[0,1,9,1 ... 
- 解决k8s故障,eureka处于unknow的问题
			//pod Unknown状态,开始强制删除eureka-server-node-0,eureka-server-node-1等,强制删除不了 [root@fp158 sts]# kubectl de ... 
- maven jar包冲突问题
			之前好端端的项目没做任何改动maven依赖就报红?jar包冲突?不要慌,问题不大. idea file里面点击invalidate Caches/Restart清空项目缓存并重启,ok解决问题. 
- Blazor 使用拖放(drag and drop)上传文件
			在很多上传文件的应用实例中, 都可以看到[拖放文件到此上传]这种骚功能 ,今天我们就来试试Blazor能不能完成这个想法. 简述HTML5拖放 拖放是HTML5标准的一部分,任何元素都能够拖放,也能够 ... 
- python爬虫---字体反爬
			目标地址:http://glidedsky.com/level/web/crawler-font-puzzle-1 打开google调试工具检查发现网页上和源码之中的数字不一样, 已经确认该题目为 字 ... 
