子数组和最大值,以及不相交子数组其和之差的最大值问题

博客介绍了最大子数组和问题及其动态规划解决方案,并提出了一个变形题目:寻找不相交连续子数组,使得它们的和之差绝对值最大。给出了解题思路和C代码实现。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

最大子数组和问题,这个大家都知道,求一个数组中和最大的连续子数组,编程珠玑上有讲过

例如 

1 2 3 4 -> 10

 -1 -2 -3 -4 -> -1

-1 2 3 -2 -> 5

-2 3-1 4 -1 ->6

有复杂度为O(n^3),O(n^2), O(nlgn)的代码,也有复杂度为O(n)的动态规划代码

#include <stdio.h>
#include <assert.h>
 
#define N 100

int max(int num1, int num2)
{
	return num1 > num2 ? num1 : num2;
}

int max_sum(int* array, int n)
{
	assert(array != NULL);
	
	int max_sofar = array[0];
	int max_until = array[0];
	
	for(int i = 1; i < n; i++)
	{
		if(max_until > 0)
		{
			max_until += array[i];
		}
		else
		{
			max_until = array[i];
		}
		max_sofar = max(max_sofar, max_until);
	}
	return max
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值