ARC120D Bracket Score 2 (模拟)
题面
给一个长度为
2
N
2N
2N 的序列
A
A
A,定义一个长度为
2
N
2N
2N 的合法括号序列的 得分(score) 为:
- 对于每对配对的括号
i
,
j
i,j
i,j,
∣
A
i
−
A
j
∣
|A_i-A_j|
∣Ai−Aj∣ 的和。
输出得分最高的任意一个合法括号序列。
1
≤
N
≤
2
⋅
1
0
5
1\leq N\leq 2\cdot10^5
1≤N≤2⋅105.
题解
我们先想一个相关的问题:
在数轴上从左到右存在
2
N
2N
2N 个点(可重合),点之间两两配对并连成线段,问最大的线段总长度。
这是一个经典问题了
考虑第一个点到第二个点之间的部分,最多会被线段覆盖一层,因为左边只有一个点;
第二个点到第三个点之间的部分,最多会被覆盖两层,因为左边只有两个点;
……
依此类推,我们能不能找到一种配对方法,使得每两个点之间的部分都达到能被覆盖的最大层数呢?
不难发现,我们可以将第一个点跟最后一个点配对,第二个点跟倒数第二配对……这是一种方法,最终答案就是后
N
N
N 个点的坐标和 - 前
N
N
N 个点的坐标和。这么看来,更一般地,我们可以在第
N
N
N 个点和第
N
+
1
N+1
N+1 个点之间划条分界线,只要每条线段都能经过这条分界线,即左边的只能和右边的配对,那么最终答案不也是后
N
N
N 个点的坐标和 - 前
N
N
N 个点的坐标和了吗?
有了这个分析,我们可以想想怎么应用在括号序列中了。
如果我们把
A
A
A 序列排个序,如果能保证前一半的点只跟后一半的点配对,那么答案一定最大化了。我们只需要满足这个条件(并且恐怕必须得满足这个条件),就是正确答案了。
那么就可以先把
A
A
A 排个序(最好带上原下标),然后把前一半的变成白点,后一半的变成黑点。
在排序前的序列中,白点黑点个数相同,那么把相邻的黑白点配对,变成左括号和右括号,再把它们在序列中删掉。由于序列中白点黑点个数一直相同,因此总有白点黑点相邻。这样就可以构造出一种合法方案了。
当然,具体实现没必要这么麻烦。这就比较考验各位的模拟能力了。
CODE
#include<set>
#include<queue>
#include<cmath>
#include<vector>
#include<cstdio>
#include<cstring>
#include<iostream>
#include<algorithm>
using namespace std;
#define MAXN 400005
#define ENDL putchar('\n')
#define LL long long
#define DB double
#define lowbit(x) ((-x) & (x))
#define INF 0x3f3f3f3f
LL read() {
LL f = 1,x = 0;char s = getchar();
while(s < '0' || s > '9') {if(s=='-')f = -f;s = getchar();}
while(s >= '0' && s <= '9') {x=x*10+(s-'0');s = getchar();}
return f * x;
}
int n,m,i,j,s,o,k;
int a[MAXN];
struct it{
int nm,id;
}b[MAXN];
bool cmp(it a,it b) {return a.nm == b.nm ? (a.id < b.id):(a.nm < b.nm);}
int main() {
n = read();
for(int i = 1;i <= 2*n;i ++) {
a[i] = read();b[i].nm = a[i];b[i].id = i;
}
sort(b + 1,b + 1 + 2*n,cmp);
for(int i = 1;i <= n;i ++) {
a[b[i].id] *= -1;
}
int ct = 0;
for(int i = 1;i <= 2*n;i ++) {
if(a[i] < 0) {
if(ct < 0) putchar(')');
else putchar('(');
ct ++;
}
else {
if(ct > 0) putchar(')');
else putchar('(');
ct --;
}
}ENDL;
return 0;
}
ARC120D Bracket Score 2 (模拟)的更多相关文章
- CodeForces - 224C. Bracket Sequence (栈模拟)简单做法
A bracket sequence is a string, containing only characters "(", ")", "[&quo ...
- Codeforces Round #350 (Div. 2) E. Correct Bracket Sequence Editor 模拟
题目链接: http://codeforces.com/contest/670/problem/E 题解: 用STL的list和stack模拟的,没想到跑的还挺快. 代码: #include<i ...
- HDU 5268 ZYB loves Score (简单模拟,水)
题意:计算Bestcoder四题的得分. 思路:直接模拟,4项分数直接计算后输出.注意不要低于百分之40的分. //#include <bits/stdc++.h> #include &l ...
- 【CF1023C】Bracket Subsequence(模拟)
题意:给定一个正则括号序列 s ,让你在当中选择一个长度正好为 t 的子串,使得 t 恰好也是一个正则括号序列 思路:用栈模拟 #include<cstdio> #include<c ...
- Codeforces Round #529 (Div. 3) E. Almost Regular Bracket Sequence (思维,模拟栈)
题意:给你一串括号,每次仅可以修改一个位置,问有多少位置仅修改一次后所有括号合法. 题解:我们用栈来将这串括号进行匹配,每成功匹配一对就将它们消去,因为题目要求仅修改一处使得所有括号合法,所以栈中最后 ...
- ACM思维题训练 Section A
题目地址: 选题为入门的Codeforce div2/div1的C题和D题. 题解: A:CF思维联系–CodeForces -214C (拓扑排序+思维+贪心) B:CF–思维练习-- CodeFo ...
- CodeForces 670E Correct Bracket Sequence Editor(list和迭代器函数模拟)
E. Correct Bracket Sequence Editor time limit per test 2 seconds memory limit per test 256 megabytes ...
- CF思维联系– Codeforces-990C Bracket Sequences Concatenation Problem(括号匹配+模拟)
ACM思维题训练集合 A bracket sequence is a string containing only characters "(" and ")" ...
- Codeforces Round #350 (Div. 2) E. Correct Bracket Sequence Editor 线段树模拟
E. Correct Bracket Sequence Editor Recently Polycarp started to develop a text editor that works o ...
随机推荐
- 2021.03.20【NOIP提高B组】模拟 总结
区间 DP 专场:愉快爆炸 T1 题目大意 有 \(n\) 个有颜色的块,连续 \(k\) 个相同颜色的就可以消掉 现在可以在任意位置插入任意颜色的方块,问最少插入多少个可以全部抵消 题解 先把连续的 ...
- .NET中检测文件是否被其他进程占用
更新记录 本文迁移自Panda666原博客,原发布时间:2021年7月2日. 一.检测文件是否被进程占用的几种方式 在.NET中主要有以下方式进行检测文件是否被进程占用的几种方式: 通过直接打开文件等 ...
- CSS 网页字体最佳实践
一般在网页的字体设置中,可以将字体分类三类: 系统字体:使用系统自带的字体 兜底字体:当系统字体无法正常使用,而兜底的字体 Emoji 字体:显示网页中的表情字体 为了满足不同平台,以及 Emoji ...
- 面试突击60:什么情况会导致 MySQL 索引失效?
为了验证 MySQL 中哪些情况下会导致索引失效,我们可以借助 explain 执行计划来分析索引失效的具体场景. explain 使用如下,只需要在查询的 SQL 前面添加上 explain 关键字 ...
- 【RPA之家转载RPA创新产业峰会回看】机器人流程自动化专利态势报告
[RPA之家转载RPA创新产业峰会回看]机器人流程自动化专利态势报告 自动化的一个专利情况的监测,就是全球监测的情况.今天我可能给大家汇报的主要是三个方面,第一个方面就是讲一下全球投资智能化的专利的一 ...
- iostat、vmstat、iftop命令详解
1.安装iostat命令 yum install sysstat -y 用法:iostat [ 选项 ] [ <时间间隔> [ <次数> ]] 常用选项说明: -c:只显示系统 ...
- RPA应用场景-账套建立
所涉人工数量5操作频率 不定时 场景流程 1.客户按照项目开设专项财务管理,每个项目需要在初期建立自己的账套: 2.运营专员通过邮件发送账套建立申请: 3.根据申请进入金蝶运维后台,依据规则完成账套建 ...
- Java去除字符串中 除数字和逗号以外的符号
例: public static void main(String[] args) { // 去除字符串中 除数字和逗号以外的符号 String str = "_1066,_1068,_10 ...
- Map集合中的同一键值key重复赋值
前言: 验证:对Map集合中的同一键值key重复赋值? 结果:对Map集合中的同一键值key重复赋值会覆盖之前的结果. 验证如下: Map<String, Object> map = ne ...
- S32Kxxx bootloader之UDS bootloader
了解更多关于bootloader 的C语言实现,请加我Q扣: 1273623966 (验证信息请填 bootloader),欢迎咨询或定制bootloader(在线升级程序). 两周前完成了基于UDS ...