贪心: Array Splitting(数列分段)(洛谷CF1175D)

在这里插入图片描述

解析

这题可以转化一下:
在这里插入图片描述
(《神笔马良》。。。。)
计算这些长方形对应下标的总加和
我们可以一层一层往上垒,假设第i层起始点为xi,总和为sumi,再设从1到i的前缀和为si
显然第一层x1=1,sum1=sn
对于第二层x2,sum2=tot[x2,n]=sn-s[x2-1]
对于第三层x3,sum3=sn-s[x3-1]
。。。
对于第k层xk,sumk=sn-s[xk-1]
最后累加sum即答案
显然答案整理一下应为k*sn-(s[x2-1]+s[x3-1]+…+s[xk-1])
要使ans最大,显然要使括号内最小
那么我们只需找出最小的k-1个(因为第一层不减)最小的前缀和再用k*sn减去他们即可
注意因为xk<=n,xk-1<n-1,所以sn是不能作为减数的

代码

#include<cstdio>
#include<cstring>
#include<cmath>
#include<algorithm>
#include<iostream>
#include<string>
#include<queue>
#include<vector>
using namespace std;
int n,k;
int a[300500];
long long s[300500]={ };
bool cmp(long long x,long long y){return x<y;
}
int main(){scanf("%d%d",&n,&k);for(int i=1;i<=n;i++){scanf("%d",&a[i]);s[i]=s[i-1]+a[i];}long long ans=s[n]*k;sort(s+1,s+n,cmp);//最后一个不能取 for(int i=1;i<=k-1;i++){ans-=s[i];}printf("%lld\n",ans);return 0;
}

AC快乐!!!

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/318830.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

牛客题霸 [合并有序链表] C++题解/答案

牛客题霸 [合并有序链表] C题解/答案 题目描述 将两个有序的链表合并为一个新链表&#xff0c;要求新的链表是通过拼接两个链表的节点来生成的。 题解&#xff1a; 首先判断l1和l2是否为空 然后依次比较l1和l2的值&#xff0c;然后存到新的链表里&#xff0c;当有一方全部结…

2021牛客暑期多校训练营2 G.League of Legends(转化+单调队列)

G.League of Legends Zechariah_2001题解 对于可以包含其他区间的大区间&#xff0c;要使得答案最优无非就是两种分组方式&#xff1a;单独一组或者与被包含的区间一组。单独一组那么贡献就是区间长度&#xff1b;如果说与被包含的区间一组&#xff0c;对答案贡献为0&#xff…

P5056-[模板]插头dp

正题 题目链接:https://www.luogu.com.cn/problem/P5056 题目大意 n∗mn*mn∗m的网格&#xff0c;求有多少条回路可以铺满整个棋盘。 解题思路 插头dpdpdp的&#xff0c;写法是按照题解上的写法。 状态用的是括号匹配&#xff0c;然后用了哈希邻接表&#xff08;挂表&#x…

牛客题霸 [用两个栈实现队列] C++题解/答案

题目描述 用两个栈来实现一个队列&#xff0c;完成队列的Push和Pop操作。 队列中的元素为int类型。 题解&#xff1a; 我们都知道栈的性质是先进后出&#xff0c;队列是先进先出 我们用两个栈来模拟出队列 可以先用一个栈来存数&#xff0c;当要输出时&#xff0c;最上面的是…

Docker最全教程——从理论到实战(一)

容器是应用走向云端之后必然的发展趋势&#xff0c;因此笔者非常乐于和大家分享我们这段时间对容器的理解、心得和实践。本篇教程持续编写了2个星期左右&#xff0c;只是为了大家更好地了解、理解和消化这个技术&#xff0c;能够搭上这波车。你可以关注我们的公众号“magiccode…

二分:路标设置(洛谷)

传送门. 解析 只需二分枚举空旷指数即可 对于单次判断的check函数&#xff0c;可以相当于n个路标把路面分成n1个间隔&#xff0c;而对于每个间隔[l,r]和空旷指数x&#xff08;边界已有路标&#xff09;&#xff0c;所需路标应为&#xff1a; (r-l-1)/x&#xff08;比如[2,5…

2020 ICPC亚洲区域赛(沈阳)F-Kobolds and Catacombs(思维+模拟)

F-Kobolds and Catacombs 考虑每一段&#xff0c;先找到最小的&#xff0c;然后把编号小于它的都化为一组&#xff0c;此时有一个最大值需要把小于最大值的在划分进来&#xff0c;然后又有编号小于它的&#xff0c;于是再把编号小于它的划分为一组&#xff0c;while1 循环一下…

P3190-[HNOI2007]神奇游乐园【插头dp】

正题 题目链接:https://www.luogu.com.cn/problem/P3190 题目大意 n∗mn*mn∗m的网格上有权值&#xff0c;求一条权值和最大的不交回路。 1≤n≤100,1≤m≤61\leq n\leq 100,1\leq m\leq 61≤n≤100,1≤m≤6 解题思路 经典的棋盘形插头dpdpdp&#xff0c;和模板不同的地方是求…

牛客题霸 [最长公共子串]C++题解/答案

牛客题霸 [最长公共子串]C题解/答案 题目描述 给定两个字符串str1和str2,输出两个字符串的最长公共子串&#xff0c;如果最长公共子串为空&#xff0c;输出-1 题解&#xff1a; lcs模板 代码&#xff1a; class Solution { public:/*** longest common substring* param …

二分:[BJWC2008]秦腾与教学评估

洛谷传送门 解析 因为至多有一个单数 假设其位置为k&#xff0c;1-i的累加和为s[i] 则s[1]-s[k-1]全是偶数 s[k]-s[max]全是奇数 答案呈单调性&#xff0c;可以用二分算法 check函数&#xff08;计算前缀和&#xff09;也很容易用O&#xff08;n&#xff09;写出&#xff1a…

微软Azure予力Green Dot客服成就不凡

点击蓝字关注我碧点公司&#xff08;Green Dot&#xff09;是仔细聆听消费者心声&#xff0c;以消费者为导向的金融科技创新公司&#xff0c;致力于为大众带来高效、便捷与体验舒适的个人银行业务。Green Dot创造了预付借记卡产业&#xff0c;也是美国最大的可增值预付借记卡和…

2020 ICPC亚洲区域赛(沈阳)H-The Boomsday Project(双指针+dp)

H-The Boomsday Project Code1 暴力我为人人区间转移 O{N∑qlog⁡N}O\{N\sum q\log N \}O{N∑qlogN} #include<bits/stdc.h> using namespace std; using lllong long; template <class Tint> T rd() {T res0;T fg1;char chgetchar();while(!isdigit(ch)) {if(c…

倍增:st表(模板)(洛谷P3865)

[传送门](https://www.luogu.com.cn/problem/P38 解析 板子题最棒了 用mx[i][j]存储以i为起点&#xff0c;长度为2^j次方的区间内的max 分成前后两段&#xff0c;则可以得到递推式&#xff1a; mx[i][k]max(mx[i][k-1],mx[imi[k-1]][k-1]);而关于初始化&#xff0c;显然&…

首届大湾区 DevOps/微服务秋季分享会圆满落幕!

在科技迅速发展的时代&#xff0c;传统行业积极开展数字化转型以在激烈竞争中脱颖而出&#xff0c;新兴行业不停歇地验证业务模式以找准市场定位&#xff1b;软件与行业变得密不可分&#xff0c;各行各业如何快速响应软件需求&#xff0c;已经成为直接关系到企业核心利益的关键…

牛客题霸 [ 大数加法]C++题解/答案

牛客题霸 [ 大数加法]C题解/答案 题解&#xff1a; 本质就是模拟加法运算 想要让s与t长度统一&#xff0c;不足的部分用0来补充 然后从最后一位开始&#xff0c;两个数相加&#xff0c;同时如果超过10&#xff0c;就把多的部分加到下一位 其实就是我们小学在草稿纸上运算加法…

codeforces1012 B. Chemical table(并查集+思维)

B. Chemical table One of the way to solve this problem is to interprete the cells in 2d matrix as an edge in the bipartite graph, that is a cell (i, j) is an edge between i of the left part and j of the right part. 将行号放一边&#xff0c;列号放一边构造…

P7099-[yLOI2020]灼【数学期望,结论】

正题 题目链接:https://www.luogu.com.cn/problem/P7099 题目大意 给出nnn个坐标轴上的点&#xff0c;qqq次询问从某点出发每次等概率向左或者向右一格求到达某个给出点的期望步数。 保证每个询问点左右都有目标点 1≤n≤105,1≤q≤5106,1≤xi,yi≤1091\leq n\leq 10^5,1\leq…

P4258-[WC2016]挑战NPC【带花树】

正题 题目链接:https://www.luogu.com.cn/problem/P4258 题目大意 给出nnn个球&#xff0c;mmm个篮筐&#xff0c;每个球都可以被放入一些特定的篮筐&#xff0c;每个球都要放&#xff0c;要求球的个数小于等于111的篮筐数量最多。 保证有解&#xff0c;输出方案。 1≤T≤5,1…

.NET Core实战项目之CMS 第五章 入门篇-Dapper的快速入门看这篇就够了

写在前面上篇文章我们讲了如在在实际项目开发中使用Git来进行代码的版本控制&#xff0c;当然介绍的都是比较常用的功能。今天我再带着大家一起熟悉下一个ORM框架Dapper&#xff0c;实例代码的演示编写完成后我会通过Git命令上传到GitHub上&#xff0c;正好大家可以再次熟悉下G…

倍增:喷泉 深度解析(洛谷P7167)

洛谷传送门 解析 什么破题 数据范围来看很明显最多到nlogn 首先&#xff0c;对于样例进行一下分析&#xff1a; 我们可以把它转化为一棵树&#xff1a; 每一个根都有对应的权&#xff0c;给你一个结点和加权和&#xff0c;问能爬到哪里 既然是树&#xff0c;自然要找爸爸…