水题 第五站 HDU Max Sum Plus Plus

本文介绍了一个关于从n个数字中选取m个不相交子串使其和最大的问题,并通过动态规划的方法给出了解决方案。文章详细解释了动态规划的状态转移方程,并附带实现代码。

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

毕竟自己还是菜得不行,这个题目是从n个数字中选出m个不相交字串,使其和最大,话说这个题目的理解就反复了好几次= =,心想这不就是选出m个最大字串,然后和不就是最大吗?然而还有不相交= =!所以完全没有思路
网上的思路,动态规划一个式子几乎让我抓狂= =,大神们的抽象思维能力好强= =,看了半天慢慢理出一点儿思路,那么
(1)对于每个数而言,有三种情况
1.1分到前面的分组
1.2独立成一组
1.3被抛弃
(2)动态规划的经典思路dp[i][j]表示j个数分为i组的最大和的值= =,结果就是dp[m][n];
(3)对应前面三种情况列式子dp[i][j]=max(dp[i][j-1]+a[j], max(dp[i-1][k]+a[j]));i-1

#include <iostream>
#include <cstdio>
#include <cstring>

using namespace std;

#define N 1000000
#define INF 0x7fffffff

int a[N+10];
int dp[N+10],Max[N+10];//max( dp[i-1][k] ) 就是上一组 0....j-1 的最大值。

int main()
{
    int n,m,mmax;
    while (~scanf("%d%d",&m,&n))
    {
        for (int i=1;i<=n;i++)
        {
            scanf("%d",&a[i]);
        }
        memset(dp,0,sizeof(dp));
        memset(Max,0,sizeof(Max));
        for (int i=1;i<=m;i++)//分成几组
        {
            mmax=-INF;
            for (int j=i;j<=n;j++)//j个数分成i组,至少要有i个数
            {
                dp[j]=max(dp[j-1]+a[j],Max[j-1]+a[j]);
                Max[j-1]=mmax;
                mmax=max(mmax,dp[j]);
            }
        }
        printf ("%d\n",mmax);
    }
    return 0;
}

坦白说,知道了思路这个代码我也写不出来,我现在只能大概理解这么写的用意,代码出处参考博客

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值