前言

因为本人尚菜,所以本篇文章没有什么数学符号,请大家放心食用。

题目分析

先吐槽一嘴,这个 o 表示 (),这个 x 表示 )(,十分形象。

好,我们先观察原序列,容易得出第一条性质:

ox 的加入不会让我们不合法的序列变合法,相反,它会让我们合法的序列变不合法。

于是可以得出,无论如何,只要我们想要得到合法的序列,我们肯定都要先将去除 ox 的括号序列变得合法。

那么惯性的思考下去,也就是我们可以将贡献拆开算,分别是忽略 ox 后的括号序列变合法的最小步数ox 步数的平衡

这个时候可能会晕的一点是,为什么可以这么拆,或者说,为什么计算最小步数的时候可以忽略中间的 ox。其实,我们并没有忽略掉我们的 ox,只不过我们运用了两个视角来计算同一件事请而已,我们先忽略 ox 从纯括号中观察得到纯括号序列的移动步数,然后再从 ox 的角度观察序列的变化。此时不但得出,对于 ox 来说,我们的变化就是原序列经过变换后的逆序对数。

然后最后一步进行 dp 就是比较朴素的,设 \(dp_{i,j}\) 为已经观察了 \(i\) 个括号和 \(j\) 个序列后,我们观察出的最小步数。

然后需要特殊考虑一下 x 的位置,不难看出,x 只能在 ( 的后面。所以转移的时候需要特判。

代码实现

这里只给出了代码的关键部分,其余部分还恳请读者自行实现。

char s[MAX_SIZE];
int posb[MAX_SIZE];
int bl[MAX_SIZE];
int posv[MAX_SIZE];
int presum[MAX_SIZE];
int n, m, k;
int dp[MAX_SIZE][MAX_SIZE];
int t1[MAX_SIZE];
int t2[MAX_SIZE]; void main() {
scanf("%s",s+1);
n=strlen(s+1);
for(int i=1;i<=n;i++){
if(s[i] == '('){
posb[++m] = i;
bl[m] = 0;
} else if(s[i] == ')'){
posb[++m] = i;
bl[m] = 1;
} else {
posv[++k] = i;
}
}
int now = 0;
int ans1 = 0;
for(int i=1;i<=m;i++){
if(bl[i] && !now){
int j=i;
while(bl[j]){
++j;
}
ans1 += j-i;
while(j>i){
swap(bl[j],bl[j-1]);
swap(posb[j],posb[j-1]);
--j;
}
}
now += (bl[i] ? -1 : 1);
presum[i] = now;
}
memset(dp,0x7f,sizeof(dp));
dp[0][0] = 0;
for(int i=0;i<=m;i++){
for(int j=0;j<=k;j++){
if(i<m){
if(j){
t1[i] += (posv[j] > posb[i+1]);
}
dp[i+1][j] = min(dp[i+1][j],dp[i][j] + t1[i]);
}
if(j<k){
if(i){
t2[j] += (posb[i] > posv[j+1]);
}
if(presum[i]>0 || s[posv[j+1]]=='o'){
dp[i][j+1] = min(dp[i][j+1],dp[i][j] + t2[j]);
}
}
}
}
printf("%lld\n",dp[m][k]+ans1);
return void();
}

题解 AGC054D的更多相关文章

  1. 2016 华南师大ACM校赛 SCNUCPC 非官方题解

    我要举报本次校赛出题人的消极出题!!! 官方题解请戳:http://3.scnuacm2015.sinaapp.com/?p=89(其实就是一堆代码没有题解) A. 树链剖分数据结构板题 题目大意:我 ...

  2. noip2016十连测题解

    以下代码为了阅读方便,省去以下头文件: #include <iostream> #include <stdio.h> #include <math.h> #incl ...

  3. BZOJ-2561-最小生成树 题解(最小割)

    2561: 最小生成树(题解) Time Limit: 10 Sec  Memory Limit: 128 MBSubmit: 1628  Solved: 786 传送门:http://www.lyd ...

  4. Codeforces Round #353 (Div. 2) ABCDE 题解 python

    Problems     # Name     A Infinite Sequence standard input/output 1 s, 256 MB    x3509 B Restoring P ...

  5. 哈尔滨理工大学ACM全国邀请赛(网络同步赛)题解

    题目链接 提交连接:http://acm-software.hrbust.edu.cn/problemset.php?page=5 1470-1482 只做出来四道比较水的题目,还需要加强中等题的训练 ...

  6. 2016ACM青岛区域赛题解

    A.Relic Discovery_hdu5982 Time Limit: 2000/1000 MS (Java/Others)    Memory Limit: 65536/65536 K (Jav ...

  7. poj1399 hoj1037 Direct Visibility 题解 (宽搜)

    http://poj.org/problem?id=1399 http://acm.hit.edu.cn/hoj/problem/view?id=1037 题意: 在一个最多200*200的minec ...

  8. 网络流n题 题解

    学会了网络流,就经常闲的没事儿刷网络流--于是乎来一发题解. 1. COGS2093 花园的守护之神 题意:给定一个带权无向图,问至少删除多少条边才能使得s-t最短路的长度变长. 用Dijkstra或 ...

  9. CF100965C题解..

    求方程 \[ \begin{array}\\ \sum_{i=1}^n x_i & \equiv & a_1 \pmod{p} \\ \sum_{i=1}^n x_i^2 & ...

  10. JSOI2016R3 瞎BB题解

    题意请看absi大爷的blog http://absi2011.is-programmer.com/posts/200920.html http://absi2011.is-programmer.co ...

随机推荐

  1. excel:if语句

    IF语法格式: IF(logical_test,value_if_true,value_if_false) 释义:判断一个条件是否满足,如果满足返回一个值,如果不满足则返回另一个值. logical_ ...

  2. 行行AI人才直播第15期:【AIGC科技公司法律顾问】Amber《AIGC的法律挑战》

    近年来,AIGC技术的迅速进步为社会经济发展带来了新的机遇.各行各业都开始关注AIGC相关技术在商业落地中的应用,AIGC相关的创业及项目如雨后春笋般涌现.然而,AIGC的广泛应用也带来了一系列的法律 ...

  3. 关于 Llama 2 的一切资源,我们都帮你整理好了

    Llama 2 是一个由 Meta 开发的大型语言模型,是 LLaMA 1 的继任者.Llama 2 可通过 AWS.Hugging Face 获取,并可以自由用于研究和商业用途.Llama 2 预训 ...

  4. c++算法之动态规划:01背包

    什么是动态规划? 动态规划算法(dynamic programing),是一种由递推为基础的比贪心更稳定的一种优化策略,为运筹学的一部分.就是通过以递推为基础的手段非暴力求出最值. 它的总体思想其实就 ...

  5. MIT6.s081/6.828 lectrue5/6:System call entry/exit 以及 Lab4 心得

    这篇博客主要复习 lecture05:GDB calling conentions 和 lecture06:System call entry/exit 的内容,外加 Lab4:traps 的心得 前 ...

  6. 9、Mybatis之动态SQL

    9.1.环境搭建 9.1.1.创建新module 创建名为mybatis_dynamicSQL的新module,过程参考5.1节 9.1.2.创建Emp实体类 package org.rain.myb ...

  7. Azure Data Factory(六)数据集类型为Dataverse的Link测试

    一,引言 之前有讲过 Azure Data Factory 的 Copy Data 的操作,演示了将 Blob Storage1 的数据通过 Azure Data Factory 复制到 Blob S ...

  8. 给DataTable添加额外字段

    //dt为DataTable dt.Columns.Add("字段名");//创建字段 //给新增字段赋值 foreach(DataRow item in dt.Rows) { i ...

  9. SQL注入简介

    SQL注入(SQL Injection)是一种计算机安全漏洞,它允许攻击者通过操纵应用程序的输入来执行恶意的SQL查询,从而访问.修改或删除数据库中的数据.这种攻击通常发生在应用程序未正确验证.过滤或 ...

  10. html页面底部添加版权信息

    话不多说,直接上代码: <!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http:/ ...