关于使用贪心思想求解数组连续最大和以及dp解子矩阵的最大和问题通讲

博客介绍了如何利用贪心策略解决数组的最大连续子序列问题,通过局部最优推导全局最优,实现O(n)的时间复杂度和O(1)的空间复杂度。接着探讨了矩阵的最大子矩阵和问题,通过将二维数组“压缩”成一维,转化为求解一维数组最大连续子序列和,应用相同思路。提供了相关代码示例,并邀请读者提问讨论。
摘要由CSDN通过智能技术生成

一_数组最大连续子序列

题目描述:给定一个数组,求出它的最大连续子序列和
思路:根据贪心策略,我们知道,由局部最优可以推导出全局最优
1.那么在本题中什么是局部最优呢?
我们可以看出每选取的一个集合(一个元素或多个元素)它的和为正数时,它对我们的最大和的全局最优是有帮助的

2.那么什么时候对我们的全局最优是没有帮助的呢?
当集合内元素的和为负数时,我们肯定不会选取这个集合内部的这几个相邻的元素.再重新选取紧邻集合右边的下一个正向元素,作为一次新的开始.

3.我们在不断选取的过程中,如何记录最大值MAX呢?
记录一个变量,这个变量记录再加入当前选取的这个元素与上一次的最大和MAX相比,取最大的即可,我们遍历完数组,发现时间复杂度为O(n),空间复杂度为O(1),是不是很棒?!
代码如下:

#include<iostream>
#include<vector>
#include<stdio.h>
using namespace std;

int main()
{
   
	vector<int> V;

	int MAX = 0;
	int n;
	int temp;
	int sum = 0;
	while (scanf_s("%d", &n) && n)
	{
   
		V.clear();	//注意每一轮开始的时候都要重新计数
		MAX = 0;
		sum = 0;
		for (<
  • 1
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

Shallow_Carl

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值