算法(27)-最大系列

最大系列

  • 1.LeetCode-239 滑动窗口的最大值
  • 2.LeetCode-53 连续子数组的最大和
  • 3.LeetCode-152 乘积最大的子数组。
  • 4.剑指 Offer 14- I. 剪绳子为k个整数段,使各个段成绩最大
    • 1.dp
    • 数学推导

1.LeetCode-239 滑动窗口的最大值

窗口由左往右最大值数组Left,和由右向左最大值数组right维护。

在这里插入代码片
    def maxSlidingWindow(self, nums: 'List[int]', k: 'int') -> 'List[int]':n = len(nums)if n * k == 0:return []if k == 1:return numsleft = [0] * nleft[0] = nums[0]right = [0] * nright[n - 1] = nums[n - 1]for i in range(1, n):# from left to rightif i % k == 0:# block startleft[i] = nums[i]else:left[i] = max(left[i - 1], nums[i])# from right to leftj = n - i - 1    # i = 1, j = n-2if (j + 1) % k == 0:# block endright[j] = nums[j]else:right[j] = max(right[j + 1], nums[j])output = []for i in range(n - k + 1): # i=[0,n-k)output.append(max(left[i + k - 1], right[i]))return output

2.LeetCode-53 连续子数组的最大和

借助连续性,如果某一块的和为负数,这一块不会作为和最大连续子数组的开头,因为去掉这个部分,后半段加和会更大。
动态规划的解题思路:dp[i] 以nums[i]结尾的连续子数组的最大和,dp[i] 只与dp[i-1]有关,空间约减后,空间复杂度为0(1)

    def maxSubArray(self, nums):""":type nums: List[int]:rtype: int"""res = float("-INF")dp = 0for val in nums:dp += val        # [-1]  先加,更新答案,确定是否归零res = max(dp, res)dp = max(dp, 0)return res

3.LeetCode-152 乘积最大的子数组。

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

直接思路:fmax(i)f_{max}(i)fmax(i)表示以第i个元素结尾的乘积最大的子数组的积,状态转移方程为
fmax(i)=max⁡i=1n{f(i−1)∗ai,ai}f_{max}(i)=\max_{i=1}^n\{f(i-1)*a_i,a_i\} fmax(i)=i=1maxn{f(i1)ai,ai}
即,fmax(i)f_{max}(i)fmax(i)可以考虑nums[i]加入前面fmax(i−1)f_{max}(i-1)fmax(i1)对应的一段,或者自成一段,这两种情况取最大值,求出所有的f_i之后,选取一个最大的作为结果。

核心问题:当前位置的最优解不一定是由前一个位置的最优解得到。因为存在正负数

如果当前的数是负数的话,我们希望以num[i-1]为结尾的某一个段的积也是一个负数,负负可以为正。

如果当前数为正,我们希望以num[i-1]为结尾的某一个段的积也是一个正数,正的越多,乘积完越大。

所以再维护一个fmin(i)f_{min}(i)fmin(i)表示以第i个元素结尾的乘积最小的子数组的积:
fmax(i)=max⁡{fmax(i−1)∗ai,fmin(i−1)∗ai,ai}fmin(i)=min⁡{fmax(i−1)∗ai,fmin(i−1)∗ai,ai}f_{max}(i)=\max\{f_{max}(i-1)*a_i,f_{min}(i-1)*a_i,a_i\}\\ f_{min}(i)=\min\{f_{max}(i-1)*a_i,f_{min}(i-1)*a_i,a_i\}fmax(i)=max{fmax(i1)ai,fmin(i1)ai,ai}fmin(i)=min{fmax(i1)ai,fmin(i1)ai,ai}

def maxProduct(self, nums):""":type nums: List[int]:rtype: int"""pre_max, pre_min = 1, 1res = float("-INF")for val in nums:cur_max = max(pre_max * val, pre_min * val, val)cur_min = min(pre_max * val, pre_min * val, val)pre_max, pre_min = cur_max, cur_minres = max(res, cur_max)return res

4.剑指 Offer 14- I. 剪绳子为k个整数段,使各个段成绩最大

给你一根长度为 n 的绳子,请把绳子剪成整数长度的 m 段(m、n都是整数,n>1并且m>1),每段绳子的长度记为 k[0],k[1]…k[m-1] 。请问 k[0]k[1]…*k[m-1] 可能的最大乘积是多少?例如,当绳子的长度是8时,我们把它剪成长度分别为2、3、3的三段,此时得到的最大乘积是18。

1.dp

dp[i]: 长度为i 绳子至少剪了一次的最长长度
dp[i]=max(dp[j]∗(i−j),j∗(i−j),dp[i]),j∈[1,i−1]dp[i] = max(dp[j]*(i-j),j*(i-j),dp[i]),j\in[1,i-1]dp[i]=max(dp[j](ij),j(ij),dp[i]),j[1,i1]

class Solution(object):def cuttingRope(self, n):""":type n: int:rtype: int"""dp = [0]*(n+1)dp[1] = 1for i in range(2,n+1):for j in range(1,i):dp[i]= max(dp[i],dp[j]*(i-j),j*(i-j))return dp[-1]

n^2复杂度的DP

数学推导

通过数学不等式推到,可以得到,当每段长度为3时乘积最大。所以尽可能分为三段,最后一段依据具体情况判断:

class Solution(object):def cuttingRope(self, n):""":type n: int:rtype: int"""if n<=3:return n-1s, mod = n //3, n % 3   if mod == 0:res = 3**selif mod == 1:res = 3**(s-1)*4 else:res = 3**s*2return res%(10**9+7)

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/444950.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

mysql数据库表的导入导出

MySQL写入数据通常用insert语句&#xff0c;如 复制代码 代码如下: insert into person values(张三&#xff0c;20)&#xff0c;&#xff08;李四&#xff0c;21&#xff09;&#xff0c;&#xff08;王五&#xff0c;70&#xff09;…; 但有时为了更快速地插入大批量数据或…

leetcode 33 搜索旋转排序数组 到处是细节的好题

这个题想了想就会做&#xff0c;只是细节真的能卡死人&#xff0c;找了好久的bug。甚至我怀疑我现在的代码可能还有错&#xff0c;只是没例子测出来。 假设按照升序排序的数组在预先未知的某个点上进行了旋转。 ( 例如&#xff0c;数组 [0,1,2,4,5,6,7] 可能变为 [4,5,6,7,0,1…

多线程中局部静态变量初始化的陷阱

C当中常常需要一个全局唯一的对象实例&#xff0c;这时候&#xff0c;我们就会想到单件模式。如何实现这一模式&#xff1f;全局变量当然是一个简单可行的方法&#xff0c;然而&#xff0c;这太丑陋。嗯&#xff0c;其实&#xff0c;丑陋倒也罢了&#xff0c;最严重的是它将引诱…

MachineLearning(8)-PCA,LDA基础+sklearn 简单实践

PCA,LDA基础sklearn 简单实践1.PCAsklearn.decomposition.PCA1.PCA理论基础2.sklearn.decomposition.PCA简单实践2.LDAsklearn.discriminant_analysis.LinearDiscriminantAnalysis2.1 LDA理论基础2.2 sklearn LDA简单实践1.PCAsklearn.decomposition.PCA 1.PCA理论基础 PCA:&…

引用变量和引用数组

前两天没事干,重拾C++的一些书籍,翻到引用这,无意写了些DD: 其实引用和指针有很多相似的地方,又有不同的(太多了,不过说到效率上,比如函数传参数,我们可以用引用,指针,哪种好呢,引用不必为站再分配空间了,而指针还学要分配4字节的空间给指针变量) 我们知道如何…

leetcode198 打家劫舍

你是一个专业的小偷&#xff0c;计划偷窃沿街的房屋。每间房内都藏有一定的现金&#xff0c;影响你偷窃的唯一制约因素就是相邻的房屋装有相互连通的防盗系统&#xff0c;如果两间相邻的房屋在同一晚上被小偷闯入&#xff0c;系统会自动报警。 给定一个代表每个房屋存放金额的…

linux下的RPC

一、概述 在传统的编程概念中&#xff0c;过程是由程序员在本地编译完成&#xff0c;并只能局限在本地运行的一段代码&#xff0c;也即其主程序和过程之间的运行关系是本地调用关系。因此这种结构在网络日益发展的今天已无法适应实际需求。总而言之&#xff0c;传统过程调用模式…

算法(28)--矩阵搜索系列

矩阵搜索1.leetcode-200. 岛屿数量2.leetcode-695. 岛屿的最大面积3.leetcode-463. 岛屿的周长4.剑指 Offer 12. 矩阵中的路径5.leetcode-329. 矩阵中的最长递增路径6.leetcode-1091. 二进制矩阵中的最短路径1.leetcode-200. 岛屿数量 给你一个由 ‘1’&#xff08;陆地&#…

leetcode213 打家劫舍II

你是一个专业的小偷&#xff0c;计划偷窃沿街的房屋&#xff0c;每间房内都藏有一定的现金。这个地方所有的房屋都围成一圈&#xff0c;这意味着第一个房屋和最后一个房屋是紧挨着的。同时&#xff0c;相邻的房屋装有相互连通的防盗系统&#xff0c;如果两间相邻的房屋在同一晚…

linux下安装boost

以下是在ubuntu 7.10 (内核 2.6.22-14)下安装的例子&#xff1a; 一、下载最新的 boost 库&#xff0c;下载地址&#xff1a; http://www.boost.org/users/download/ 二、在适当的位置解压 boost 库&#xff0c;推荐把 boost 库解压到 /usr/local/ 下&#xff1a; $ cd dowlo…

PaperNotes(4)-高质量图像生成-CGAN-StackGAN-Lapgan-Cyclegan-Pix2pixgan

cgan,stackgan,lapgan,cyclegan,pix2pixgan1.Conditional GAN1.1简介1.2网络结构与训练1.3特点与用途2.Stack GAN2.1简介2.2网络结构与训练2.3特点与用途3.Lap GAN3.1简介3.2网络结构与训练3.3特点与用途4.Pix2pix GAN4.1 简介4.2 网络结构和训练4.3 特点和用途5.Patch GAN6.Cy…

关于c++的一些案例

之前做项目的时候,有时候会用到位,也就是将一些数据放在二进制里,然后存在数据库中或者缓存在服务器上,取出来,然后要判断某位是不是置0或1,然后再将某位置0或1(比如领多个奖励的 游戏逻辑),之前有点傻,竟然用 << ,>>这些运算符计算,今天翻起以前好久不…

C++(1)--概况、开发工具、hello word

简介1. 概况2. 开发工具3. mac 写hello word4. c 基本概念5.两个数相加代码分解5.1编译预处理命令# include5.2输入输出库iostream6.注释7.编码规范《老九学堂C课程》《C primer》学习笔记。《老九学堂C课程》详情请到B站搜索《老九零基础学编程C入门》1. 概况 20世纪70年代&a…

class 和 struct的区别

C中的struct对C中的struct进行了扩充&#xff0c;它已经不再只是一个包含不同数据类型的数据结构了&#xff0c;它已经获取了太多的功能。 struct能包含成员函数吗&#xff1f; 能&#xff01; struct能继承吗&#xff1f; 能&#xff01;&#xff01; struct能实现多态吗&…

leetcode206 反转链表

反转一个单链表。 示例: 输入: 1->2->3->4->5->NULL 输出: 5->4->3->2->1->NULL 进阶: 你可以迭代或递归地反转链表。你能否用两种方法解决这道题&#xff1f; 经典题不解释 /*** Definition for singly-linked list.* public class ListNode…

浅议柔性数组

很多时候,柔性数组应用在了变长结构体中,如: StructPacket {Int state; Int len;

leetcode 152 乘积最大子序列

给定一个整数数组 nums &#xff0c;找出一个序列中乘积最大的连续子序列&#xff08;该序列至少包含一个数&#xff09;。 示例 1: 输入: [2,3,-2,4] 输出: 6 解释: 子数组 [2,3] 有最大乘积 6。 示例 2: 输入: [-2,0,-1] 输出: 0 解释: 结果不能为 2, 因为 [-2,-1] 不是子…

PaperNotes(5)-Conditional Generative Adversarial Nets

Conditional GAN 论文阅读笔记Abstract1 Introduction2 Related Work3 Conditional Adversarial Nets3.1 Generative Adversarial Nets3.2 Conditional Adversarial Nets4 Experimental Results4.1 Unimodal4.2 Multimodal5 Future Work6.思考文章地址&#xff1a;https://arxi…

蛙泳姿势教学

偶尔看到分享的一篇日志&#xff0c;记录下&#xff0c;忙过这段时间努力学蛙泳。 蛙泳配合有一个顺口溜&#xff0c;在讲解蛙泳动作要领之前先介绍给大家&#xff1a;“划手腿不动&#xff0c;收手再收腿&#xff0c;先伸胳膊后蹬腿&#xff0c;并拢伸直漂一会儿。”从顺口溜中…

leetcode238 除本身以外数组的乘积

给定长度为 n 的整数数组 nums&#xff0c;其中 n > 1&#xff0c;返回输出数组 output &#xff0c;其中 output[i] 等于 nums 中除 nums[i] 之外其余各元素的乘积。 示例: 输入: [1,2,3,4] 输出: [24,12,8,6] 说明: 请不要使用除法&#xff0c;且在 O(n) 时间复杂度内完…