P3648 [APIO2014]序列分割

\(part1:\)

首先看到题目,嗯~ o( ̄▽ ̄)o很骚

手玩一波样例之后发现状态很好想(这里简单地任务阶段可以被划分次数(也就是划分顺序)和划分位置来划分),初步想法是\(f[i][j]\)表示前\(i\)次最后一次切的是\(j\)位置

随后意识到没法通过上一层进行转移,这里出现问题也是正常,因为没有进行更深入地发掘性质

此处无法转移的原因是切的顺序不知道,真让人头大

\(part2:\)

观察到题目中计算分数的方法很骚,和的乘积

这两种运算都比较特殊,都有交换律

然后发现答案与切的顺序无关

\(part1\)中的问题迎刃而解,修正状态得:\(f[i][j]\)表示前\(i\)给数分成\(j\)段的最大值

\(part3:\)

开始转移

\(f[i][j]=min\{f[k][j-1]+s[k]*(s[i]-s[k]\}\)

\(s[i]\)时前缀和

复杂度:\(O(n^2*k)\)

得分:\(50\)
注意此代码中\(i\)和\(j\)的含义和上面反着,抱歉

#include<bits/stdc++.h>
#define int long long int
using namespace std;
inline int read() {
    int f=1,s=0;
    char c=getchar();
    while(c<'0'||c>'9') {
        if(c=='-') f=-1;
        c=getchar();
    }
    while(c>='0'&&c<='9') {
        s=s*10+c-'0';
        c=getchar();
    }
    return f*s;
}
const int N=2020;
int road[N][250],n,K,f[N][250],sum[N],a[N];
signed main() {
    n=read(),K=read();
    for(int i=1; i<=n; ++i) a[i]=read();
    for(int i=1;i<=n;++i) sum[i]=sum[i-1]+a[i];
    for(int i=1; i<=n; ++i) {
        for(int j=1; j<=i-1; ++j) {
            for(int k=1; k<=K; ++k) {
                if(f[k][i]<=f[k-1][j]+sum[j]*(sum[i]-sum[j])) {
                    f[k][i]=f[k-1][j]+sum[j]*(sum[i]-sum[j]);
                    road[k][i]=j;
                }
            }
        }
    }
    cout<<f[K][n]<<'\n';
    int t=n;
    for(int i=K;i>=1;--i)
    {
        t=road[i][t];
        cout<<t<<' ';
    }
    return 0;
}

原文地址:https://www.cnblogs.com/pyyyyyy/p/12305573.html

时间: 2024-10-31 08:10:54

P3648 [APIO2014]序列分割的相关文章

P3648 [APIO2014]序列分割 斜率优化

题解:斜率优化\(DP\) 提交:\(2\)次(特意没开\(long\ long\),然后就死了) 题解: 好的先把自己的式子推了出来: 朴素: 定义\(f[i][j]\)表示前\(i\)个数进行\(j\)次切割的最大得分,\(s[i]\)为前缀和 那么转移方程为: \(f[i][j]=\max(f[i-1][j]+s[j]*(s[i]-s[j]))\) 优化一下(省掉第一维): \(f[i]=\max(mem[j]+s[j]*(s[i]-s[j])\),\(f[j])\),\(mem[j]\)

【斜率DP】BZOJ 3675:[Apio2014]序列分割

3675: [Apio2014]序列分割 Time Limit: 40 Sec  Memory Limit: 128 MBSubmit: 1066  Solved: 427[Submit][Status][Discuss] Description 小H最近迷上了一个分割序列的游戏.在这个游戏里,小H需要将一个长 度为N的非负整数序列分割成k+l个非空的子序列.为了得到k+l个子序列, 小H将重复进行七次以下的步骤: 1.小H首先选择一个长度超过1的序列(一开始小H只有一个长度为n的 序列一一也就

[bzoj3675] [Apio2014]序列分割 Split the sequence  dp+斜率优化

3675: [Apio2014]序列分割 Time Limit: 40 Sec Memory Limit: 128 MB Submit: 1538 Solved: 637 [Submit][Status][Discuss] Description 小H最近迷上了一个分隔序列的游戏.在这个游戏里,小H需要将一个长度为n的非负整数序列分割成k+1个非空的子序列.为了得到k+1个子序列,小H需要重复k次以下的步骤: 1.小H首先选择一个长度超过1的序列(一开始小H只有一个长度为n的序列--也就是一开始

bzoj3675[Apio2014]序列分割 斜率优化dp

3675: [Apio2014]序列分割 Time Limit: 40 Sec  Memory Limit: 128 MBSubmit: 3508  Solved: 1402[Submit][Status][Discuss] Description 小H最近迷上了一个分隔序列的游戏.在这个游戏里,小H需要将一个长度为n的非负整数序列分割成k+1个非空的子序列.为了得到k+1个子序列,小H需要重复k次以下的步骤: 1.小H首先选择一个长度超过1的序列(一开始小H只有一个长度为n的序列——也就是一开

bzoj 3675 [Apio2014]序列分割(斜率DP)

[题目链接] http://www.lydsy.com/JudgeOnline/problem.php?id=3675 [题意] 将n个数的序列分割k次,每次的利益为分割后两部分数值和的积,求最大利益. [思路] 设f[i][j]表示将前i个分割j次的最大获益,则有转移式: f[i][j]=max{ f[k][j-1]+(S(i)-S(k))*S(k) } 设a<b,若b决策优于a决策则有: (S[b]^2-S[a]^2+f[a][j-1]-f[b][j-1])/(S[b]-S[a])<S[i

【bzoj 3675】[Apio2014]序列分割

Description 小H最近迷上了一个分隔序列的游戏.在这个游戏里,小H需要将一个长度为n的非负整数序列分割成k+1个非空的子序列.为了得到k+1个子序列,小H需要重复k次以下的步骤: 1.小H首先选择一个长度超过1的序列(一开始小H只有一个长度为n的序列--也就是一开始得到的整个序列): 2.选择一个位置,并通过这个位置将这个序列分割成连续的两个非空的新序列. 每次进行上述步骤之后,小H将会得到一定的分数.这个分数为两个新序列中元素和的乘积.小H希望选择一种最佳的分割方式,使得k轮之后,小

动态规划(斜率优化):BZOJ 3675 [Apio2014]序列分割

Description 小H最近迷上了一个分割序列的游戏.在这个游戏里,小H需要将一个长 度为N的非负整数序列分割成k+l个非空的子序列.为了得到k+l个子序列, 小H将重复进行七次以下的步骤: 1.小H首先选择一个长度超过1的序列(一开始小H只有一个长度为n的 序列一一也就是一开始得到的整个序列): 2.选择一个位置,并通过这个位置将这个序列分割成连续的两个非空的新 序列. 每次进行上述步骤之后,小H将会得到一定的分数.这个分数为两个新序 列中元素和的乘积.小H希望选择一种最佳的分割方案,使得

【bzoj3675】[Apio2014]序列分割 斜率优化dp

原文地址:http://www.cnblogs.com/GXZlegend/p/6835179.html 题目描述 小H最近迷上了一个分隔序列的游戏.在这个游戏里,小H需要将一个长度为n的非负整数序列分割成k+1个非空的子序列.为了得到k+1个子序列,小H需要重复k次以下的步骤: 1.小H首先选择一个长度超过1的序列(一开始小H只有一个长度为n的序列--也就是一开始得到的整个序列): 2.选择一个位置,并通过这个位置将这个序列分割成连续的两个非空的新序列. 每次进行上述步骤之后,小H将会得到一定

BZOJ 3675 APIO2014 序列分割 斜率优化

题目大意:给定一个序列,可以分割k次,每次分割的得分为两段序列的和的乘积 求最大得分 首先我们可以推出序列的分割顺序是不影响得分的 比如说我要把一个序列分割成四份ABCD 我先分割A BCD或者先分割AB CD最后的得分是一样的 证明?嗯--易证.显然嘛.哈哈.好吧我不会证...自己画一下推推就好 好吧这是神犇的证法:比如我将ABCD分割为AB CD 那么A就和CD各乘了一次 B也和CD各乘了一次 再分割AB时A和B也乘了一次 最后可以保证所有的序列对(X,Y)在任何一种分割法中都只乘了一次 然