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的更多相关文章
随机推荐
- linux学习(三)系统目录结构
登录系统后,在当前命令窗口下输入命令: ls / 你会看到如下图所示: 树状目录结构: 以下是对这些目录的解释: /bin:bin是Binary的缩写, 这个目录存放着最经常使用的命令. /boot: ...
- logistic 回归(线性和非线性)
一:线性logistic 回归 代码如下: import numpy as np import pandas as pd import matplotlib.pyplot as plt import ...
- zz高精地图和定位在自动驾驶的应用
本次分享聚焦于高精地图在自动驾驶中的应用,主要分为以下两部分: 1. 高精地图 High Definition Map 拓扑地图 Topological Map / Road Graph 3D栅格地图 ...
- 快速傅立叶变换(FFT)
多项式 系数表示法 设\(f(x)\)为一个\(n-1\)次多项式,则 \(f(x)=\sum\limits_{i=0}^{n-1}a_i*x_i\) 其中\(a_i\)为\(f(x)\)的系数,用这 ...
- 重构 改善既有代码的设计 (Martin Fowler 著)
第1章 重构, 第一个案例 1.1 起点 1.2 重构的第一步 1.3 分解并重组 statement() 1.4 运用多态取代与价格相关的条件逻辑 1.5 结语 第2章 重构原则 2.1 何谓重构 ...
- Metersploit系统参数说明
Back参数 Back参数主要⽤用于返回.⽐比如你进⼊入了了某⼀一个漏漏洞洞模块的设置,但是你想再重新选择一个漏漏洞洞模块,那么就需要⽤用到back参数. 这张图说明,才开始我使用了ms08_067_ ...
- 基于Django的Rest Framework框架的版本控制
本文目录 一 作用 二 内置的版本控制类 三 局部使用 四 全局使用 五 示例 源码分析 回到目录 一 作用 用于版本的控制 回到目录 二 内置的版本控制类 from rest_framework.v ...
- mybatis的参数传递
mybatis的参数传递分为两种:1.单参数传递 2.多参数传递 单参数 mybatis会直接取出参数值给Mapper文件赋值 例子如下: 1.Mapper文件内容如下: public void d ...
- Mysql 常用数据类型 占用字节数 [转]
数据类型是定义列中可以存储什么数据以及该数据实际怎么存储的基本规则.Mysql的常用数据类型主要有: 串数据类型:最常用的数据类型,有两种基本的串类型:分别为定长串和不定长串.定长串结束长度固定的字符 ...
- jvm的组成入门
JVM的组成分为整体组成部分和运行时数据区组成部分. JVM的整体组成 JVM的整体组成可以分为4个部分:类加载器(Classloader).运行时数据区(Runtime Data Area).执行引 ...