首页 > 其他分享 >Educational Codeforces Round 165 (Rated for Div. 2) C. Minimizing the Sum题解

Educational Codeforces Round 165 (Rated for Div. 2) C. Minimizing the Sum题解

时间:2024-05-01 23:56:57浏览次数:35  
标签:Educational Rated const 题解 ll long le include minv

题意

Codeforces Round 809 (Div. 2) D1. Chopping Carrots (Easy Version)

给你两个整数\(n(1 \le n \le 3e5), k(0\le k \le 10)\), 一个数组 \(a(1 \le a_i \le 10^9)\)。你可以进行如下操作最多 \(k\) 次:选定一个数 \(i(1 \le i \le n)\),让其变为相邻的数(变为\(a_{i-1}, a_{i+1}\)中的一个),\(a_1\) 与 \(a_n\) 不相邻。
输出数组各个元素之和最小值。

思路

这道题观察数据范围可以猜测解法可能与 \(k\) 有关,复杂度可能为 \(O(nk), O(nk^2)\) 甚至 \(O(nk^3)\) 。

打假一下贪心做法,就是时刻维护相邻元素的差,每次操作都选取最大的差来操作。
例如如下数据:

4 2
120 70 1 80

如果按照贪心思路,最后数组变为了120 1 1 1,但正确结果的数组应该是1 1 1 80

这道题需要提取出如下的性质:

  • 如果一段区间被操作了,那么最终的数组一定是这个区间中的最小值
  • 操作的区间与区间之间不会有交叉部分

这里就要用到dp来解决(一般我的各种算法都不行,贪心也被hack时候,就会考虑dp)。
设定 \(f_{i,j}\) 表示前 \(i\) 个元素中,用了 \(j\) 次操作后的元素之和的最小值。
根据定义,表示出状态转移: \(f_{i,j} = min\{f_{i-1,j} + minv * 1, f_{i-2,j-1} + minv * 2, ..., f_{i-(k+1),j-k} + minv * (k+1) \}\)。其中 \(minv\) 表示 \([i-d-1,i]\) 区间中的最小值

代码

#include <algorithm>
#include <cmath>
#include <cstring>
#include <iostream>
#include <map>
#include <queue>
#include <set>
#include <stack>
#include <string>
#include <vector>
#include <bitset>

#define fi first
#define se second

using namespace std;
using ll = long long;
using ull = unsigned long long;
using pii = pair<int, int>;

const ll inf = 0x3f3f3f3f3f3f3f3f;
const ull P = 131;
const double eps = 1e-4;
const int N = 3e5+10, M = 11;

ll n, k, a[N];
ll f[N][M];

void solve() {
    scanf("%lld%lld", &n, &k);
    for (int i=1; i<=n; i++)
        scanf("%lld", &a[i]);
    for (int i=0; i<=n; i++)
        for (int j=0; j<=k+1; j++)
            f[i][j] = inf;

    f[0][0] = 0;
    for (int i=1; i<=n; i++) {
        for (int j=0; j<=k; j++) {
            ll minv = a[i];
            for (int d=0; d<=j && i-d-1>=0; d++) {
                minv = min(minv, a[i-d]);
                f[i][j] = min(f[i][j], f[i-d-1][j-d] + minv * (d + 1));
            }
        }
    }
    
    ll res = inf;
    for (int i=0; i<=k; i++) res = min(res, f[n][i]);
    printf("%lld\n", res);
}

int main() {
    // multiple case
    int t; scanf("%d", &t);
    while(t--) {
        solve();
    }

    // single case
    // solve();

    return 0;
}

标签:Educational,Rated,const,题解,ll,long,le,include,minv
From: https://www.cnblogs.com/1v7w/p/18169783

相关文章

  • P1017 [NOIP2000 提高组] 进制转换 题解
    题目简述给定一个十进制数$n$,将其转换成一个$-R$进制数。题目分析十进制数转负进制,同样可以使用短除取余法,但是会出现余数为负的情况,例如$-11\div-2=5~\cdots\cdots-1$,此时我们可以用如下法方解决此问题:我们设被除数为$a$,除数为$b$,余数为$c$,商为$d$,其中$c<0$......
  • P2192 HXY玩卡片 题解
    题目简述给定一些$5$和$0$的数字,让你在其中选择一些数进行排列成为一个非负整数,使得这个数字能被$90$整除,且是所有满足条件的数中最大的一个,无解输出$-1$。题目分析如果一个数能被$90$整除,那么它一定能被$9$和$10$整除。能被$10$整除,那就说面答案的个位数一定......
  • [题解]P4597 序列 sequence
    P4597序列sequence是CF13CSequence的加强版,\(N\leq5*10^5\)。如果想了解\(O(N^2)\)的DP解法请看此文。给定\(N\)个数,每次操作可以选其中一个数\(+1\)或\(-1\)。请问要让这个数列不降,最少需要多少次操作?看到数据范围发现不能用\(O(N^2)\)的dp了,需要换一种思路。我们用类......
  • [题解]CF13C Sequence
    CF13CSequence给定\(N\)个数,每次操作可以选其中一个数\(+1\)或\(-1\)。请问要让这个数列不降,最少需要多少次操作?我们用DP解决。对\(a\)从小到大排序,存在\(c\)中。我们用\(f[i][j]\)表示让前\(i\)个元素满足条件,而且这些元素最大值不超过\(c[j]\)的最小操作次数。状态转移方......
  • 异或与区间加题解
    异或与区间加题解简要题意给定\(n,m,K,a_{1...n}\),和\(m\)个三元组\((x_i,y_i,z_i)\),定义\(calc(l,r)=a_l\bigoplusa_{l+1}\bigoplus...\bigoplusa_r\)。对于每个三元组\((x,y,z)\),对所有满足\(x\lel\ler\ley\,\calc(l,r)=K\)的区间\((l,r)\)内的每个数\(b......
  • CF1967B2 Reverse Card (Hard Version) 题解
    题意:求有多少对\((a,b)\)满足\(b\times\gcd(a,b)\equiv0\pmod{a+b},1\lea\len,1\leb\lem\)。首先我们设\(\gcd(a,b)=G,a=i\timesG,b=j\timesG\),显然有\(\gcd(i,j)=1\)。那么可以把原条件转化为\(j\timesG\)是\((i+j)\)的倍数。因为\(\gcd(i+......
  • Codeforces Round 942 Div.2 题解
    蹭个热度,挽救一下cnblogs蒸蒸日上的阅读量。Q:你是手速狗吗?A:我觉得我是。2A因为选的\(w\)一定可以让它合法,一次操作可以看作\(a\)数组向右平移一位。枚举操作次数后暴力判断即可。#include<bits/stdc++.h>voidwork(){ intn; std::cin>>n; std::vector<......
  • 【题解】 量化交易5
    题目描述applepi训练了一个可以自动在股票市场进行量化交易的模型。通常来说,applepi写出的模型,你懂得,就好比一架印钞机。不过为了谨慎起见,applepi还是想先检查一下模型的效果。applpie收集了“塞帕思股份(surpass)”在最近的连续N天内的价格。在每一天中,他可以做如下事情之一:......
  • Educational Codeforces Round 165 (Rated for Div. 2) 题解
    A对于\(i\top_i\)连边。如果存在二元环,则答案为2。否则答案为3。B非降序排序:0全部在1前面。令0的个数为z。从左往右,将前z个全部填上0。填第\(i\)位时,每次填的最小代价为:若第\(i\)位为1,第\(i\)位右边的第一个0到\(i\)之间的字符个数。(贪心)......
  • 【题解】 量化交易4
    题目描述applepi训练了一个可以自动在股票市场进行量化交易的模型。通常来说,applepi写出的模型,你懂得,就好比一架印钞机。不过为了谨慎起见,applepi还是想先检查一下模型的效果。applpie收集了“塞帕思股份(surpass)”在最近的连续N天内的价格。在每一天中,他可以做如下事情之一:......