题面

给一个长度为

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 (模拟)的更多相关文章

  1. CodeForces - 224C. Bracket Sequence (栈模拟)简单做法

    A bracket sequence is a string, containing only characters "(", ")", "[&quo ...

  2. Codeforces Round #350 (Div. 2) E. Correct Bracket Sequence Editor 模拟

    题目链接: http://codeforces.com/contest/670/problem/E 题解: 用STL的list和stack模拟的,没想到跑的还挺快. 代码: #include<i ...

  3. HDU 5268 ZYB loves Score (简单模拟,水)

    题意:计算Bestcoder四题的得分. 思路:直接模拟,4项分数直接计算后输出.注意不要低于百分之40的分. //#include <bits/stdc++.h> #include &l ...

  4. 【CF1023C】Bracket Subsequence(模拟)

    题意:给定一个正则括号序列 s ,让你在当中选择一个长度正好为 t 的子串,使得 t 恰好也是一个正则括号序列 思路:用栈模拟 #include<cstdio> #include<c ...

  5. Codeforces Round #529 (Div. 3) E. Almost Regular Bracket Sequence (思维,模拟栈)

    题意:给你一串括号,每次仅可以修改一个位置,问有多少位置仅修改一次后所有括号合法. 题解:我们用栈来将这串括号进行匹配,每成功匹配一对就将它们消去,因为题目要求仅修改一处使得所有括号合法,所以栈中最后 ...

  6. ACM思维题训练 Section A

    题目地址: 选题为入门的Codeforce div2/div1的C题和D题. 题解: A:CF思维联系–CodeForces -214C (拓扑排序+思维+贪心) B:CF–思维练习-- CodeFo ...

  7. CodeForces 670E Correct Bracket Sequence Editor(list和迭代器函数模拟)

    E. Correct Bracket Sequence Editor time limit per test 2 seconds memory limit per test 256 megabytes ...

  8. CF思维联系– Codeforces-990C Bracket Sequences Concatenation Problem(括号匹配+模拟)

    ACM思维题训练集合 A bracket sequence is a string containing only characters "(" and ")" ...

  9. 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 ...

随机推荐

  1. 一文掌握软件安全必备技术 SAST

    上一篇文章中,我们讨论了软件供应链的概念并了解到近年来软件供应链安全事件层出不穷.为了保障软件供应链安全,我们需要了解网络安全领域中的一些主要技术.本篇文章将介绍其中一个重要技术--SAST. 当开发 ...

  2. BUUCTF-被嗅探的流量

    被嗅探的流量 提示告知是文件传输的流量,那进去过滤http流量包即可,找到一个upload目录的,并且是post方式即可,追踪http流即可发现flag

  3. linux-基于tensorflow2.x的手写数字识别-基于MNIST数据集

    数据集 数据集下载MNIST 首先读取数据集, 并打印相关信息 包括 图像的数量, 形状 像素的最大, 最小值 以及看一下第一张图片 path = 'MNIST/mnist.npz' with np. ...

  4. 集成学习——GBDT(手推公式)

  5. 使用C++的ORM框架QxORM

    QxORM中,我们用的最多的无非是这两点 官方表述是这样的: 持久性: 支持最常见的数据库,如 SQLite.MySQL.PostgreSQL.Oracle.MS SQL Server.MongoDB ...

  6. Linux 源码编译安装软件

    程序包编译安装的步骤: 源代码-->预处理-->编译-->汇编-->链接-->执行 多文件:文件中的代码之间,很可能存在跨文件依赖关系 1.编译源码的项目工具 使用相关的 ...

  7. sql-DDL-约束

    约束 对表中的数据进行限定,保证数据的正确性.有效性和完整性. 6个约束 1. 主键约束Primary Key: 唯一,不能为null -- 主键约束.和唯一约束不能同时设置 1. 含义:非空且唯一 ...

  8. C++ 练气期之一文看懂字符串

    C++ 练气期之细聊字符串 1. 概念 程序不仅仅用于数字计算,现代企业级项目中更多流转着充满了烟火气的人间话语.这些话语,在计算机语言称为字符串. 从字面上理解字符串,类似于用一根竹签串起了很多字符 ...

  9. 【RocketMQ】消息的存储

    Broker对消息的处理 BrokerController初始化的过程中,调用registerProcessor方法注册了处理器,在注册处理器的代码中可以看到创建了处理消息发送的处理器对象SendMe ...

  10. vmstate 命令详解2022

    vmstat 是一个查看虚拟内存(Virtual Memory)使用状况的工具,但是怎样通过 vmstat 来发现系统中的瓶颈呢? 1. 使用vmstat 使用前我们先看下命令介绍及参数定义 Usag ...