luoguP4393Sequence
https://www.luogu.org/problem/P4393
题意
给你n个点的一个数列,每次可以合并两个相邻的数为他们的最大值,且代价为这两个数的最大值,求将整个序列合并为1个数的最小代价
n≤1e6
分析
个人做这题很玄.....
我们先考虑三个数a,b,c , 且序列的顺序为{a, b, c}的情况...可得
当 a < b < c时,在最优的情况下, 最大值c只有一次被计算在内(即只对最终的代价 的贡献是一个c), 并且,b被算了一次。
当a < b, b > c时, 最大值b被计算了两次,而a和没有被计算在内
这样,多画几个图自己看看(虽然找规律(即找贪心的策略)花费的时间可能比较多...像我做这题的时候就是在纸上涂涂画画...), 然后我们就可以得出贪心策略:
我们将每个点 i 与它左右两边相邻点i-1, i+1比较大小,并记录比a[i]小的相邻点的个数is[i](0, 1 或2),那么a[i]对答案(即最终代价)的贡献就是a[i]*is[i].
证明: a[i]>a[i-1] && a[i]>a[i+1]时, 无论怎么合并 i 两边的数, 到后来, a[i]总被计算两次。
只有一个成立时(假设是a[i]>a[i+1]不成立), a[i]总被计算一次,而a[i+1]的计算次数就 >= 1了,a[i] 一定是与a[i+1]合并的。
注意合并操作的实现和边界1, n的is值即可(其实我也就是试试,谁知道真过了emm....
#include<cstdio>
using namespace std;
#define ll long long
#define MAX 1000000
int n;
int a[MAX];
int is[MAX];
int main() {
scanf("%d", &n);
for(int i = 1; i <= n; i++) scanf("%d",&a[i]);
for(int i = 2; i < n; i++) {
if(a[i] >= a[i+1]) {
is[i]++;
if(a[i] == a[i+1]) is[i+1]--;
}
if(a[i] >= a[i-1])
is[i]++;
}
if(a[1] > a[2]) is[1] = 1;
if(a[n] > a[n-1]) is[n] = 1;
ll ans = 0;
for(int i = 1; i <= n; i++) {
ans += (ll)a[i]*is[i];
}
printf("%lld",ans);
}
luoguP4393Sequence的更多相关文章
随机推荐
- FFT_应用和例题
卷积 现有两个定义在 N 上的函数 \(f(n),g(n)\),定义 \(f\) 和 \(g\) 的卷积(convolution)为 \(f \otimes g\) \[ (f \otimes g)( ...
- WinCC中通过脚本禁用或启用Windows快捷键
有些项目要求WinCC全屏运行,并禁止通过操作系统快捷键切换到桌面,这时只需要在WinCC的计算机属性中勾选“禁用用于进行操作系统访问的快捷键”.此后当WinCC运行时,按Win键或Ctrl+Alt+ ...
- java虚拟机规范学习笔记之数据类型
1.1 class文件格式 编译后被Java虚拟机所执行的代码使用了一种平台中立的二进制格式来表示,并且经常以文件的形式来存储,这种格式称为class文件格式.class文件格式中精确的定义了类与接口 ...
- 在macOS苹果电脑上安装Azure DevOps Server(TFS)代理
1. 概述 MacOS是一套运行于苹果Macintosh系列电脑上的操作系统,是首个在商用领域成功的图形用户界面操作系统.Iphone应用软件的开发人员,都使用运行macOS的电脑或mini盒子进行软 ...
- (三十三)golang--面向对象之继承
继承可以解决代码复用: 实现:只需要在结构体中嵌套一个匿名结构体: 结构体可以使用匿名结构体中所有字段核方法:无论是大写还是小写: 可以简化访问匿名结构体中的属性和方法: 当该结构体和匿名结构体有相同 ...
- 网易云信技术分享:IM中的万人群聊技术方案实践总结
本文来自网易云信团队的技术分享,原创发表于网易云信公众号,原文链接:mp.weixin.qq.com/s/LT2dASI7QVpcOVxDAsMeVg,收录时有改动. 1.引言 在不了解IM技术的人眼 ...
- Linux网络编程基础API
第5章 Linux网络编程基础API 探讨Linux网络编程基础API与内核中TCP/IP协议族之间的关系,并未后续章节提供编程基础.从3个方面讨论Linux网络API. socket地址API.so ...
- 用 qemu-user 在arm linux机器上运行amd64/x86程序
1. qemu-user 是什么 本来, 对于 QEmu, 我只知道它是一个模拟器, 可以像 VirtualBox/VMWare 那样跑一个操作系统, 只不过 QEmu 可以在 AMD64 上面跑针对 ...
- SpringCloud之Eureka详细的配置
介绍 SpringCloud是一个完整的微服务治理框架,包括服务发现和注册,服务网关,熔断,限流,负载均衡和链路跟踪等组件. SpringCloud-Eureka主要提供服务注册和发现功能.本文提供了 ...
- IDEA不能读取配置文件,springboot配置文件无效、IDEA resources文件夹指定