首页
学习
活动
专区
圈层
工具
发布
首页
学习
活动
专区
圈层
工具
MCP广场
社区首页 >专栏 >2021-10-18:乘积最大子数组。给你一个整数数组 nums

2021-10-18:乘积最大子数组。给你一个整数数组 nums

原创
作者头像
福大大架构师每日一题
修改2021-10-19 09:56:55
修改2021-10-19 09:56:55
2890
举报

2021-10-18:乘积最大子数组。给你一个整数数组 nums ,请你找出数组中乘积最大的连续子数组(该子数组中至少包含一个数字),并返回该子数组所对应的乘积。力扣152。

福大大 答案2021-10-18:

动态规划。

情况1.i位置。i。

情况2.i位置向左扩。i*dpi-1。dpi-1是最大累乘积。

情况3.i位置向左扩。i*dpi-1。dpi-1是最小累乘积。

时间复杂度:O(N)。

空间复杂度:O(1)。

代码用golang编写。代码如下:

代码语言:txt
复制
package main

import (
    "fmt"
    "math"
)

func main() {
    arr := []int{2, 3, -2, 4}
    ret := maxProduct(arr)
    fmt.Println(ret)
}

func max(arr []float64) float64 {
    if len(arr) == 0 {
        return 0 // 报错!
    }
    n := len(arr)
    // 上一步的最大
    premax := arr[0]
    // 上一步的最小
    premin := arr[0]
    ans := arr[0]
    for i := 1; i < n; i++ {
        p1 := arr[i]
        p2 := arr[i] * premax
        p3 := arr[i] * premin
        curmax := math.Max(math.Max(p1, p2), p3)
        curmin := math.Min(math.Min(p1, p2), p3)
        ans = math.Max(ans, curmax)
        premax = curmax
        premin = curmin
    }
    return ans
}

func maxProduct(nums []int) int {
    ans := nums[0]
    min := nums[0]
    max := nums[0]
    for i := 1; i < len(nums); i++ {
        curmin := getMin(nums[i], getMin(min*nums[i], max*nums[i]))
        curmax := getMax(nums[i], getMax(min*nums[i], max*nums[i]))
        min = curmin
        max = curmax
        ans = getMax(ans, max)
    }
    return ans
}
func getMax(a int, b int) int {
    if a > b {
        return a
    } else {
        return b
    }
}
func getMin(a int, b int) int {
    if a < b {
        return a
    } else {
        return b
    }
}

执行结果如下:

在这里插入图片描述
在这里插入图片描述

左神java代码

原创声明:本文系作者授权腾讯云开发者社区发表,未经许可,不得转载。

如有侵权,请联系 cloudcommunity@tencent.com 删除。

原创声明:本文系作者授权腾讯云开发者社区发表,未经许可,不得转载。

如有侵权,请联系 cloudcommunity@tencent.com 删除。

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档