IT数码 购物 网址 头条 软件 日历 阅读 图书馆
TxT小说阅读器
↓语音阅读,小说下载,古典文学↓
图片批量下载器
↓批量下载图片,美女图库↓
图片自动播放器
↓图片自动播放器↓
一键清除垃圾
↓轻轻一点,清除系统垃圾↓
开发: C++知识库 Java知识库 JavaScript Python PHP知识库 人工智能 区块链 大数据 移动开发 嵌入式 开发工具 数据结构与算法 开发测试 游戏开发 网络协议 系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程
数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁
 
   -> 数据结构与算法 -> 动态规划问题 最大子序和 -> 正文阅读

[数据结构与算法]动态规划问题 最大子序和

题目: 给定一个整数数组 nums ,找到一个具有最大和的连续子数组(子数组最少包含一个元素),返回其最大和。(LeetCode 53题)
输入:nums = [-2,1,-3,4,-1,2,1,-5,4]
输出:6
解释:连续子数组 [4,-1,2,1] 的和最大,为 6 。

官方的解释是这样的:假设nums 数组的长度是 n,下标从 0 到 n-1。

我们用 f(i) 代表以第 i 个数结尾的连续子数组的最大和,那么很显然我们要求的答案就是:

max{f(i)} 0<=i<=n-1

因此我们只需要求出每个位置的 f(i),然后返回 f 数组中的最大值即可。那么我们如何求 f(i) 呢?我们可以考nums[i] 单独成为一段还是加入 f(i-1) 对应的那一段,这取决于 nums[i] 和 f(i-1) + nums[i]的大小,我们希望获得一个比较大的,于是可以写出这样的动态规划转移方程:

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

这个答案最开始让我迷惑的点就是以第 i 个数结尾的连续子数组的最大和,后来看到了一个答案让我明白了这句话。
我们在找子数组的时候第一个想到的总是以哪个元素开头的子数组比如[1,2,3]以1开头的子数组有[1] [1,2] [1,2,3]。但是上面说的让我迷惑的那句话是以某个数为结尾来找连续子数组比如以3为结尾的子数组有[3] [2,3] [1,2,3]。只要想通了从连续数组的结尾为基准那么上面那个动态规划转移方程就不难理解了。

根据方程,我们只需要遍历一遍数组就可以得到结果

public class Solution {
    public int MaxSubArray(int[] nums) {
       int max=nums[0];	//连续子数组最大和也就是方程中的f(i),用第一个元素初始化  
       int pre=nums[0];	//用来存储f(i-1),最开始存的是f(0)
       for(int i=1;i<nums.Length;i++){
			pre=Math.Max(pre+nums[i],nums[i]);	//这一步取f(i)的值
			max=Math.Max(max,pre);	//选出最大的f(i)
		}
       return max;
    }
}
  数据结构与算法 最新文章
【力扣106】 从中序与后续遍历序列构造二叉
leetcode 322 零钱兑换
哈希的应用:海量数据处理
动态规划|最短Hamilton路径
华为机试_HJ41 称砝码【中等】【menset】【
【C与数据结构】——寒假提高每日练习Day1
基础算法——堆排序
2023王道数据结构线性表--单链表课后习题部
LeetCode 之 反转链表的一部分
【题解】lintcode必刷50题<有效的括号序列
上一篇文章      下一篇文章      查看所有文章
加:2021-08-07 12:20:33  更:2021-08-07 12:21:12 
 
开发: C++知识库 Java知识库 JavaScript Python PHP知识库 人工智能 区块链 大数据 移动开发 嵌入式 开发工具 数据结构与算法 开发测试 游戏开发 网络协议 系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程
数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁

360图书馆 购物 三丰科技 阅读网 日历 万年历 2024年11日历 -2024/11/25 18:35:02-

图片自动播放器
↓图片自动播放器↓
TxT小说阅读器
↓语音阅读,小说下载,古典文学↓
一键清除垃圾
↓轻轻一点,清除系统垃圾↓
图片批量下载器
↓批量下载图片,美女图库↓
  网站联系: qq:121756557 email:121756557@qq.com  IT数码