首页 > 其他分享 >「解题报告」CF1442D Sum

「解题报告」CF1442D Sum

时间:2023-01-09 17:00:41浏览次数:45  
标签:cnt int CF1442D Sum long 解题 MAXN len sum

首先可以发现,如果我们选了两堆且两堆均没选完,那么如果我们将较小的一个改成选较大的一个的下一个,这样一直选一定是更优的,最后肯定会使一些堆全部选完,一些堆没选,一个堆选了一部分。

考虑枚举选了一部分的那一堆,然后将其它堆看作一个物品做背包。这样同一个物品被加了狠多次,我们考虑分治,每次在一层上将某一半加进去,再递归到另一半(有点类似于线段树分治),这样复杂度就变成了 \(O(nk \log n)\)。

代码:

#include <bits/stdc++.h>
using namespace std;
const int MAXN = 3005;
int n, k;
vector<long long> a[MAXN];
long long sum[MAXN];
int len[MAXN];
long long f[30][MAXN];
long long ans = 0;
long long tmp[MAXN];
void solve(int l, int r, int cnt) {
    if (l == r) {
        cnt--;
        tmp[0] = f[cnt][0];
        for (int i = 1; i <= k; i++) {
            tmp[i] = max(tmp[i - 1], f[cnt][i]);
        }
        long long pre = 0;
        for (int i = 0; i <= min(k, len[l]); i++) {
            if (i) pre += a[l][i - 1];
            ans = max(ans, tmp[k - i] + pre);
        }
        return;
    }
    int mid = (l + r) >> 1;
    for (int i = 0; i <= k; i++) f[cnt][i] = f[cnt - 1][i];
    for (int i = mid + 1; i <= r; i++) {
        for (int j = k; j >= len[i]; j--) {
            f[cnt][j] = max(f[cnt][j], f[cnt][j - len[i]] + sum[i]);
        }
    }
    solve(l, mid, cnt + 1);
    for (int i = 0; i <= k; i++) f[cnt][i] = f[cnt - 1][i];
    for (int i = l; i <= mid; i++) {
        for (int j = k; j >= len[i]; j--) {
            f[cnt][j] = max(f[cnt][j], f[cnt][j - len[i]] + sum[i]);
        }
    }
    solve(mid + 1, r, cnt + 1);
}
int main() {
    scanf("%d%d", &n, &k);
    for (int i = 1; i <= n; i++) {
        scanf("%d", &len[i]);
        for (int j = 1; j <= len[i]; j++) {
            int b; scanf("%d", &b);
            a[i].push_back(b);
            sum[i] += b;
        }
    }
    memset(f, 0xef, sizeof f);
    f[0][0] = 0;
    solve(1, n, 1);
    printf("%lld\n", ans);
    return 0;
}

标签:cnt,int,CF1442D,Sum,long,解题,MAXN,len,sum
From: https://www.cnblogs.com/apjifengc/p/17037568.html

相关文章

  • P3426 [POI2005]SZA-Template 解题报告
    一道思维难度较高的KMP题目,对border性质要求较高。Description给定一个字符串$s$,求长度最小的前缀$t$满足"匹配"完$s$,这里的"匹配"可以看原题目,不太好描述,建议......
  • P7114 [NOIP2020] 字符串匹配 解题报告
    ~~NOIP的蓝题果然还是好难啊啊啊啊~~前言:作为一道NOIP的真题,这道题放在T2难度并不是特别大,不过考点还是比较偏的,扩展KMP和树状数组的组合,并且还带有一定的思维难度,......
  • Kafka学习笔记(十二):Java Consumer
    JavaConsumerStringboostrapServers="127.0.0.1:9092";StringgroupId="my-second-application";Stringtopic="demo_java";//createconsumerconfigsProp......
  • Kafka学习笔记(九):CLI Consumer in Groups & Consumer Groups
    CLIConsumerinGroupswithkafka-console-consumer.sh#Replace"kafka-console-consumer.sh"#by"kafka-console-consumer"or"kafka-console-consumer.bat"base......
  • AtCoder Beginner Conest 284 解题报告
    AtCoderBeginnerConest284解题报告\(\text{ByDaiRuiChen007}\)\(\text{ContestLink}\)A.SequenceofStrings模拟,时间复杂度\(\Theta(n)\)#include<bits/stdc......
  • Codeforces - 1656E - Equal Tree Sums(构造 + 树论 + 图论 + 搜索、结论题、*2200)
    1656E-EqualTreeSums(⇔源地址)目录1656E-EqualTreeSums(⇔源地址)tag题意思路AC代码错误次数:0tag⇔*2200、⇔构造、⇔树论、⇔图论、⇔搜......
  • [ABC257Ex] Dice Sum 2 题解
    [ABC257Ex]DiceSum2Solution目录[ABC257Ex]DiceSum2Solution更好的阅读体验戳此进入题面SolutionCodeUPD更好的阅读体验戳此进入题面存在$n$个正六面体骰......
  • [ABC256F] Cumulative Cumulative Cumulative Sum 题解
    [ABC256F]CumulativeCumulativeCumulativeSumSolution目录[ABC256F]CumulativeCumulativeCumulativeSumSolution更好的阅读体验戳此进入题面SolutionCodeUPD更......
  • CF1779C Least Prefix Sum 题解
    可能更好的阅读体验题目传送门题目大意给定一个序列\(a\),长度\(n\)。每次操作可以把\(a_i\)变成\(-a_i\)。要求\(a\)做前缀和之后的序列\(s\)中最小值为\(s......
  • 解题报告目录
    解怪题选择性报告(22.6.5~)关键词:低配版解题报告。22.10.10T3mountains关键词:隐藏。22.10.9T4种树关键词:隐藏。图论上的状压DP计数问题关键词:如题。22......