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的更多相关文章
随机推荐
- 简述ECMAScript6新增特性
1.变量 var 可以重复声明.只有函数级的作用域.存在变量提升 let 不能重复声明.有块级作用域.没有变量提升.变量 const 不能重复声明.具有块级作用域.常量 2.箭头函数 a.为了方便而存 ...
- pandas分组统计:groupby,melt,pivot_table,crosstab的用法
groupby: 分组 melt: 宽表转长表 pivot_table: 长表转宽表,数据透视表 crosstab: 交叉表 / 列联表,主要用于分组频数统计 import numpy as np i ...
- 【CF525E】Anya and Cubes(meet in middle)
点此看题面 大致题意: 在\(n\)个数中选任意个数,并使其中至多\(k\)个数\(x_i\)变为\(x_i!\),求使这些数和为\(S\)的方案数. \(meet\ in\ middle\) 这应该 ...
- 【CometOJ】Comet OJ - Contest #8 解题报告
点此进入比赛 \(A\):杀手皇后(点此看题面) 大致题意: 求字典序最小的字符串. 一场比赛总有送分题... #include<bits/stdc++.h> #define Tp tem ...
- jdk自带监控程序jvisualvm的使用
监控小程序的配置 生产环境tomcat的配置 编辑应用所在的tomcat服务器下的bin目录下的catalina.sh文件,修改如下: 配置如下内容: export JAVA_OPTS="- ...
- telnet: Unable to connect to remote host: No route to host
用iptables -F这个命令来关闭防火墙,但是使用这个命令前,千万记得用iptables -L查看一下你的系统中所有链的默认target,iptables -F这个命令只是清除所有规则,只不会真正 ...
- torch_12_BigGAN全文解读
1.摘要: 尽管近来生成图片模型取得了进步,成功生成了高分辨率的图片,但是在复杂的数据集中,样本的多样性仍然是难以捉摸的目标.本文尝试在大规模上训练生成对抗网络,并研究这种规模下的不稳定性.我们发现将 ...
- 微信小程序开发语音识别文字教程
微信小程序开发语音识别文字教程 现在后台 添加插件 微信同声传译 然后app.json 加入插件 "plugins": { "WechatSI": { &quo ...
- 七道常见的Redis面试题分享(含个人解答)
绝大部分写业务的程序员,在实际开发中使用 Redis 的时候,只会 Set Value 和 Get Value 两个操作,对 Redis 整体缺乏一个认知.这里以面试题的形式对 Redis 常见问题做 ...
- 云原生生态周报 Vol. 13 | Forrester 发布企业级容器平台报告
业界要闻 近日,全球知名市场调研机构 Forrester 发布首个企业级公共云容器平台报告.其中,阿里云容器服务的市场表现全球前三.中国第一,同时创造中国企业最好成绩,进入强劲表现者象限.报告显示,阿 ...