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

动态规划 —— 子数组系列-环形子数组的最大和

1. 环形子数组的最大和

题目链接:

918. 环形子数组的最大和 - 力扣(LeetCode)icon-default.png?t=O83Ahttps://leetcode.cn/problems/maximum-sum-circular-subarray/description/

 


2. 题目解析


3. 算法原理

状态表示:以某一个位置为结尾或者以某一个位置为起点

  

f[i]表示:以i位置为结尾的所有子树中的最大和

  

g[i]表示:以i位置为结尾的所有子树中的最小和

  

2. 状态转移方程

  

f[i]分为两种情况:1. 长度为1        nums[i]

  

                              2. 长度大于1    nums[i] + f[i-1] 

 

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

g[i]分为两种情况:

                              1. 长度为1        nums[i]

  

                              2. 长度大于1    nums[i] + g[i-1] 

  

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

3. 初始化 :把dp表填满不越界,让后面的填表可以顺利进行

  

我们可以在左边加上一个虚拟节点,为了不影响最终结果,那么就可以把这个虚拟节点初始化为0  

   

本题的下标映射关系:下标统一往后移动一位

  

4. 填表顺序 

  

本题的填表顺序是:从左往右

5. 返回值 :题目要求 + 状态表示     

  

本题的返回值是:1. 找到f表里的最大值,fmax

   

                              2.找到g表里的最小值,gmin,  gmin在对比之前要先用sum - gmin再进行比较

 在这里我们要考虑数组里全是负数的情况,比如为{-1,-2,-3},那么fmax的值就是-1,gmin的值就是三个数相加,sum - gmin的结果就为0,这样题目就不允许,所以我们要加上一个判断条件:

  

当sum和gmin相等的时候说明数组里面的值都是负数,那么就直接返回fmax,否则就返回两者相比之后的值

  


4.  代码

动态规划的固定四步骤:1.  创建一个dp表

                                        2. 在填表之前初始化

                                        3. 填表(填表方法:状态转移方程)

                                        4. 确定返回值

class Solution {
public:
    int maxSubarraySumCircular(vector<int>& nums) {
        int n=nums.size();
        vector<int>f(n+1),g(n+1);
        

    int fmax=INT_MIN,gmin=INT_MAX,sum=0;

        for(int i=1;i<=n;i++)
        {
            int x=nums[i-1];//加上一个虚拟节点下标-1
            f[i]=max(x,f[i-1]+x);
            fmax=max(f[i],fmax);
            
            g[i]=min(x,g[i-1]+x);
            gmin=min(g[i],gmin);
            sum+=x;
        }
            return sum==gmin?fmax:max(fmax,sum-gmin);
    }
};

未完待续~ 


http://www.kler.cn/a/393034.html

相关文章:

  • 文件输入输出——NOI
  • 大厂的 404 页面都长啥样?看看你都见过吗~~~
  • ArkTs简单入门案例:简单的图片切换应用界面
  • 什么是数字图像?
  • [代码随想录Day10打卡] 理论基础 232.用栈实现队列 225. 用队列实现栈 20. 有效的括号 1047. 删除字符串中的所有相邻重复项
  • uniapp+vue2 设置全局变量和全局方法 (兼容h5/微信小程序)
  • react中如何在一张图片上加一个灰色蒙层,并添加事件?
  • C#进阶-快速了解IOC控制反转及相关框架的使用
  • 2024-09-01 - 分布式集群网关 - LoadBalancer - 阿里篇 - 流雨声
  • Spring Boot项目的配置文件有哪些?加载优先级谁最高?配置优先级谁最高?
  • <项目代码>YOLOv8 草莓成熟识别<目标检测>
  • 昇思25天学习打卡营第1天|快速入门
  • DBeaver 连接 OceanBase Oracle 租户
  • Spring框架之观察者模式 (Observer Pattern)
  • 全球经济风雨飘摇,OJK能带领印尼金融创新走多远?
  • 更改Ubuntu22.04锁屏壁纸
  • Unity 性能优化方案
  • docker overlay磁盘空间过高的处理方案
  • 网络技术-网桥模式
  • LVQ 神经网络的 MATLAB 函数详解
  • 大数据面试题--kafka夺命连环问(前15问)
  • Vue3 -- 项目配置之commitlint【企业级项目配置保姆级教程5】
  • D3的竞品有哪些,D3的优势,D3和echarts的对比
  • 服务器集群不做负载均衡可以吗?
  • 鸿蒙进阶篇-属性动画-animateTo转场动画
  • K8S实现反向代理,负载均衡