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

网站建设网站优化相关资讯文章营销咨询师招聘

网站建设网站优化相关资讯文章,营销咨询师招聘,做区块链网站的公司,凡科网网站后台建设个人主页 : 个人主页 个人专栏 : 《数据结构》 《C语言》《C》《算法》 文章目录 前言一、题目解析二、解题思路解题思路状态表示状态转移方程初始化填表顺序返回值 三、代码实现总结 前言 本篇文章仅是作为小白的我的一些理解,,…

在这里插入图片描述

个人主页 : 个人主页
个人专栏 : 《数据结构》 《C语言》《C++》《算法》

文章目录

  • 前言
  • 一、题目解析
  • 二、解题思路
    • 解题思路
    • 状态表示
    • 状态转移方程
    • 初始化
    • 填表顺序
    • 返回值
  • 三、代码实现
  • 总结


前言

本篇文章仅是作为小白的我的一些理解,,如果有错误的地方,希望大佬们指出。


918. 环形子数组的最大和

一、题目解析

在这里插入图片描述
求环型数组中连续子数组最大和。

二、解题思路

解题思路

关于子数组的最大和,其有两种情况。
在这里插入图片描述
对于情况1而言,我们只需要正常使用dp求最大子数组和即可。
对于情况2而言,如果我们使用前缀和 与 后缀和 求和来求最大子数组和就相对麻烦,但如果我们先求最小子数组和呢?
在这里插入图片描述

情况二:求最大子数组和,就可以转换为数组和(sum) - 最小子数组和。

状态表示

该题的状态表示:经验(以该位置为终点 / 以该位置为起点) + 题目要求
在这里插入图片描述
那么对于情况1记为 f() ,f [ i ]表示以 i 位置为终点的所以子数组的最大和。
那么对于情况2记为 g(),g [ i ]表示以 i 位置为终点的所以子数组的最小和。

状态转移方程

情况1
对于在数组 i 位置的元素,我们可以将其分成两个状态。
在这里插入图片描述

即 f [i]的长度等于1,和 f [i]的长度大于1。
当 f [i]的长度等于1时,此时子数组最大和不就是该元素的大小,即f [i] = nums[i]
当 f [i]的长度大于1时,此时子数组最大和不就是 之前子数组最大和(f[i-1]) + 该元素大小,即f[i] = f[i-1] + nums[i]
那么我们对这两种情况取最大值即可得 f [ i ] 的状态转移方程。
在这里插入图片描述

情况2
和情况1类似,对于情况2,我们同样可以以 i位置,分成两种状态。
在这里插入图片描述
即 g [i]的长度等于1,和 g [i]的长度大于1。
当 g [i]的长度等于1时,此时子数组最小和不就是该元素的大小,即g [i] = nums[i]
当 g [i]的长度大于1时,此时子数组最小和不就是 之前子数组最小和(g[i-1]) + 该元素大小,即g[i] = g[i-1] + nums[i]
那么我们对这两种状态取最小值,既可以得到 g [i]的状态转移方程
在这里插入图片描述

初始化

我们要求 f [i]就要先知道 f [i -1],但如果当 i = 0时,f [i-1]就会越界。那么我们虚拟一块空间,将整个 f[i] 后移一个位置。如下所示:
在这里插入图片描述
如果我们进行这样的操作,有两点需要注意。

  • 如何填写 f[0]保证后续填表结果正确?
    只要f[0] = 0即可,毕竟f[1] = max(f[0], f[0]+nums[0])此时f[0] == f[0] + nums[0]
  • 映射关系
    因为整个f[i]后移了一个,所以f[i] 所对应的元素 nums[i]相对前移了,即f[i] 与 nums[i-1]的元素相对应。

填表顺序

要求f[i],就要先知道f[i-1],那么我们就要从前向后遍历数组nums,来填表。

返回值

我们只需要 返回情况1 与 情况2 的最大值即可。
但对于{-1, -2, -3, -4}而言,情况2 的值是:sum(-10) - gmin(-10)等于0,情况1 的值是:fmax(-1)。那么返回值就是0,结果错误。所以要先判断gmin == sum,如果相等,表示此时数组全是负数,返回fmax即可。如果不相等,返回情况1 与 情况2 的最大值即可。

三、代码实现

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++){f[i] = max(f[i-1] + nums[i-1], nums[i-1]);fmax = max(f[i], fmax);g[i] = min(g[i-1] + nums[i-1], nums[i-1]);gmin = min(g[i], gmin);sum += nums[i-1];}return sum == gmin? fmax: max(fmax, sum - gmin);}
};

总结

以上就是我对于环形子数组的最大和的理解。感谢支持!!!
在这里插入图片描述

http://www.yayakq.cn/news/972434/

相关文章:

  • 五一网站个人空间电脑软件下载网站
  • 网站被k有什么表现互联网装饰网站
  • php网站里放asp托管型网站
  • 网站站群建设wordpress文章调用插件
  • 春哥 响应式网站建设英文网页如何制作
  • 中山网站建设案例大连网络推广广告代理
  • 广德做网站wordpress搭论坛
  • 手机网站制作教程下载wordpress wp roket
  • 模板出售网站源码重庆建设网官网
  • 莱芜网站优化有哪些响应式学校网站
  • 唐山快速建站的公司网站设计思路
  • 企业网站设计文档中国合伙人2做的什么网站
  • 网站浮动条wordpress插件安装不
  • html5微信网站模板国家高新技术企业认定标准
  • 智能模板网站建设工具网页网站开发项目设计
  • 浙江网站建站网页制作与网站设计代码
  • 网站支付开发室内设计师网上接单
  • html5网站源代码下载物流手机网站模板
  • 生物技术网站开发网络营销的十大特点
  • 淄博网站公司域名是不是网址的地址
  • 建设网站女装名字大全网站建设情况的汇报
  • 钢铁网站模板网站已经开发怎样用微信实现手机网站开发
  • 高校网站一般采用什么网页布局企业网站开发背景则么写
  • 怎么做自己的发卡网站百度搜索引擎技巧
  • 网站轮播广告静安广州网站建设
  • 最简单做网站关键词网站推广
  • 延安城乡建设规划局网站网站流量 盈利
  • 成都科技网站建设找国外的工业设计网站
  • 如何做自己的网站或者论坛展示网站和营销网站的区别
  • 中国空间站首次太空授课微信招聘网站建设