【动态规划算法练习】day6

news2025/1/11 7:37:16

文章目录

  • 一、53. 最大子数组和
    • 1.题目简介
    • 2.解题思路
    • 3.代码
    • 4.运行结果
  • 二、918. 环形子数组的最大和
    • 1.题目简介
    • 2.解题思路
    • 3.代码
    • 4.运行结果
  • 三、152. 乘积最大子数组
    • 1.题目简介
    • 2.解题思路
    • 3.代码
    • 4.运行结果
  • 总结


一、53. 最大子数组和

1.题目简介

53. 最大子数组和
给你一个整数数组 nums ,请你找出一个具有最大和的连续子数组(子数组最少包含一个元素),返回其最大和。
子数组是数组中的一个连续部分。
在这里插入图片描述

2.解题思路

在这里插入图片描述

3.代码

class Solution {
public:
    int maxSubArray(vector<int>& nums) {
        //以i元素为结尾的连续数组的最大和
        vector<int> dp(nums.size(), 0);
        int ret = nums[0];
        dp[0] = nums[0];
        for(int i = 1;i < nums.size(); ++i)
        {
            dp[i] = max(nums[i], dp[i - 1] + nums[i]);
            ret = max(ret, dp[i]);
        }
        return ret;
    }
};

4.运行结果

在这里插入图片描述

二、918. 环形子数组的最大和

1.题目简介

918. 环形子数组的最大和
给定一个长度为 n 的环形整数数组 nums ,返回 nums 的非空 子数组 的最大可能和 。
环形数组 意味着数组的末端将会与开头相连呈环状。形式上, nums[i] 的下一个元素是 nums[(i + 1) % n] , nums[i] 的前一个元素是 nums[(i - 1 + n) % n] 。
子数组 最多只能包含固定缓冲区 nums 中的每个元素一次。形式上,对于子数组 nums[i], nums[i + 1], …, nums[j] ,不存在 i <= k1, k2 <= j 其中 k1 % n == k2 % n 。
在这里插入图片描述
在这里插入图片描述

2.解题思路

在这里插入图片描述

3.代码

class Solution {
public:
    int maxSubarraySumCircular(vector<int>& nums) {
        vector<int> f(nums.size(), 0);//以i元素为结尾的连续数组的最大和
        vector<int> g(nums.size(), 0);//以i元素为结尾的连续数组的最小和
        int flag = 1;//假设全为负数
        int fmax = nums[0], gmin = nums[0];
        f[0] = g[0] = nums[0];
        int sum = nums[0];
        for(int i = 1;i < nums.size(); ++i)//最大和
        {
            if(nums[i] > 0) flag = 0;
            f[i] = max(nums[i], f[i - 1] + nums[i]);
            fmax = max(fmax, f[i]);
            g[i] = min(nums[i], g[i - 1] + nums[i]);
            gmin = min(gmin, g[i]);
            sum += nums[i];
        }
        if(flag) return fmax;
        return max(fmax, sum - gmin);
    }
};

4.运行结果

在这里插入图片描述

三、152. 乘积最大子数组

1.题目简介

152. 乘积最大子数组
给你一个整数数组 nums ,请你找出数组中乘积最大的非空连续子数组(该子数组中至少包含一个数字),并返回该子数组所对应的乘积。
测试用例的答案是一个 32-位 整数。
子数组 是数组的连续子序列。
在这里插入图片描述

2.解题思路

在这里插入图片描述

3.代码

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

4.运行结果

在这里插入图片描述


总结

今天是算法练习的第6天。
有志者事竟成,继续加油。
如果本篇文章对你有所启发的话,希望可以多多支持作者,谢谢大家!

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

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

相关文章

【Java】Java 纪录类(Record Class)及代码示例

本文仅供学习交流使用&#xff01; Java Record Class相关文章地址&#xff1a; https://www.liaoxuefeng.com/wiki/1252599548343744/1331429187256353 https://www.baeldung.com/java-record-keyword https://www.developer.com/java/java-record-class/ Java中的记录类是什么…

SSMP整合案例(7) MybatisPlus快速service业务层开发

上文 SSMP整合案例(6) 业务service层逻辑编写我们创建并编写了service业务层代码 但是 这样一个一个去写 确实是有点麻烦 重复性工作 但其实这个已经有人帮我们考虑好了 MP就帮我们做了一个 service快捷开发的方式 我们在项目中的service包下创建一个接口 叫 IBookService 其实…

fscan安装以及使用

windows安装 1.go语言下载。 下载msi版本&#xff0c;直接安装就可以不用配置环境变量&#xff0c;默认是帮你安装配合好的 https://go.dev/dl/ 2.配置go环境 使用默认配置的话&#xff0c;下载速度过慢&#xff0c;导致无法完成编译。故需要配置代理。 在cmd命令行中…

RocketMQ --- 基础篇

一、MQ介绍 1.1、为什么要用MQ 消息队列是一种“先进先出”的数据结构 其应用场景主要包含以下3个方面 1.1.1、应用解耦 系统的耦合性越高&#xff0c;容错性就越低。以电商应用为例&#xff0c;用户创建订单后&#xff0c;如果耦合调用库存系统、物流系统、支付系统&…

Shapley值法介绍及实例计算

Shapley值法介绍及实例计算 为解决多个局中人在合作过程中因利益分配而产生矛盾的问题,属于合作博弈领域。应用 Shapley 值的一大优势是按照成员对联盟的边际贡献率将利益进行分配,即成员 i 所分得的利益等于该成员为他所参与联盟创造的边际利益的平均值。 本文从Shapl…

【裸机开发】EPIT 定时器 —— 按键消抖

实际工程中&#xff0c;不能直接通过延时来消抖 ! 这里我们采用定时器来消抖&#xff0c;这也是内核处理消抖的一种方式。 目录 一、基本原理 1、延时消抖的弊端 2、定时器消抖原理 二、按键消抖实现 1、按键中断 2、定时器中断 三、附加&#xff1a;按键 / 定时器中断初…

熊哥保佑你 计算机组成原理复习

移码是符号位取反 . . Cache——主存地址映像&#xff1a; 全相联&#xff1a;块号字块内地址 直接映射&#xff1a;标记行号字块内地址 组相联&#xff1a;标记组号字块内地址 一个单元一个字节 2路组相联&#xff1a; 全相联&#xff1a; 直接映射&#xff1a; . …

代码随想录算法训练营第四十七天| 198.打家劫舍、 213.打家劫舍II 、 337.打家劫舍III

打家劫舍 题目链接&#xff1a;力扣 确定dp数组&#xff08;dp table&#xff09;以及下标的含义 dp[i]&#xff1a;截至到i位置的房屋&#xff0c;最多可以偷窃的金额为dp[i]。确定递推公式 决定dp[i]的关键因素就是第i房间偷还是不偷。如果偷第i房间&#xff0c;那么dp[i] …

Ceph分布式存储系统搭建

目录 安装部署示例 &#xff08;一&#xff09;准备环境 1). 设置主机名 2). 关闭防火墙 3).添加sdb磁盘并格式化 4).配置hosts解析文件 5).配置免密登录 6).同步时区 7). 安装 Ceph 包 &#xff08;二&#xff09;创建 Ceph 集群 1、 安装ceph-deploy管理工具 2、 …

【C++】STL——string类的基本介绍、string常见的使用、string类的接口说明、string类的容量操作

文章目录 1.C语言的字符串2.C标准库中的string类2.1string类2.2string类的常用接口说明2.3string类对象的容量操作 1.C语言的字符串 在C语言中&#xff0c;字符串被表示为字符数组。C语言中的字符串以’\0’字符&#xff08;null字符或字符串结束符&#xff09;结尾&#xff0c…

了解 Splashtop 的多层安全防护措施

随着技术的进步&#xff0c;如何确保数据安全也越来越重要。Splashtop 作为行业领先的远程访问软件供应商&#xff0c;对这一点非常了解。Splashtop 基于信任、客观性、监控和隐私搭建安全框架&#xff0c;致力于保护所有数据交互和用户设备。 了解 Splashtop 安全性的核心 S…

图像色彩增强相关论文阅读-Representative Color Transform for Image Enhancement(ICCV2021)

文章目录 Representative Color Transform for Image EnhancementAbstractIntroductionRelated workMethod实验Conclusion Representative Color Transform for Image Enhancement 作者&#xff1a;Hanul Kim1, Su-Min Choi2, Chang-Su Kim3, Yeong Jun Koh 单位&#xff1a;S…

MySQL调优系列(八)——事务和锁分类

一、事务是什么 事务是逻辑上的一组操作&#xff0c;要么都执行&#xff0c;要么都不执行。 sql语句如下&#xff1a; # 开启事务 START TRANSACTION; # 多条 SQL 语句 SQL1,SQL2... ## 提交事务 COMMIT;二、事务的特性&#xff08;ACID&#xff09; 原子性&#xff08;Atom…

线上商城开发都有哪些方法?费用多少

随着如今网络环境的愈发成熟&#xff0c;人们的消费习惯开始逐渐向线上迁移&#xff0c;为了能满足此种需求&#xff0c;企业商家都开始了线上商城的建设&#xff0c;希望能借助网络的力量促进自身的发展&#xff0c;创造更高的盈利空间&#xff0c;那么如何搭建一个线上商城呢…

Zookeeper 从安装到应用

博主介绍&#xff1a; ✌博主从事应用安全和大数据领域&#xff0c;有8年研发经验&#xff0c;5年面试官经验&#xff0c;Java技术专家✌ Java知识图谱点击链接&#xff1a;体系化学习Java&#xff08;Java面试专题&#xff09; &#x1f495;&#x1f495; 感兴趣的同学可以收…

GPIO模拟时序控制外设3——AT24C02

文章目录 前言AT24C02简介引脚介绍器件寻址寻址流程器件地址的组成其他I2C器件的地址组成 通信流程1.完整的传输过程2.初始化管脚3.起始信号4.停止信号5.MCU发送8位数据5.MCU接收应答位6.MCU接收八位数据7.MCU发送应答位 AT24C02写一个字节AT24C02读一个字节实现的效果 总结 前…

如何利用VS打包C++程序

如何将VS开发的C程序打包发给别人使用呢&#xff1f;话不多说&#xff0c;跟随以下步骤即可完成&#xff1a; 打包步骤 一.安装插件1.项目-->扩展-->管理扩展2.搜索-->下载3.下载完毕-->关闭VS4.Modify-->End Tasks&#xff08;跳过&#xff09;-->完成 二.配…

5.用python写网络爬虫,动态内容

目录 ​​​​​​​前言 5.1 动态网 页 示例 5.2 对动态网页进行逆向工程 5.2.1 边界情况 5.3 渲染动态网页 5.3.1 PyQt还是PySide 5.3.2 执行 JavaScript 5.3.3 使用WebKit与网站交互 1 . 等待结果 2. 渲染类 5.3.4 Selenium 5.4 本章小结 前言 根据联合国全球 网站可…

《诸神之眼:Nmap网络安全审计技术揭秘》读书笔记

《诸神之眼&#xff1a;Nmap网络安全审计技术揭秘》读书笔记 作者&#xff1a;李华峰 ◆ 前言 NSE是Nmap中革命性的创新。通过Nmap强大的脚本引擎&#xff08;NSE&#xff09;&#xff0c;每一个用户都可以向Nmap中添加自己编写的代码&#xff0c;从而将Nmap打造成用户自由定制…

Ansys Speos | material library 材料库提升仿真效率

概述 Speos 在不断更新细节功能的同时&#xff0c;不断地优化材料属性应用过程&#xff0c;旨在帮助用户在相同的项目或是不同的项目之间通用材料属性定义&#xff0c;甚至扩展到公司内部不同的设计人员之间数据的通用&#xff0c;减少光学材料属性定义花费时间&#xff0c;提升…