URAL 1183.Brackets Sequence ( DP+记录路径)

2024-08-21 08:08

本文主要是介绍URAL 1183.Brackets Sequence ( DP+记录路径),希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

题意:加入最少数量的括号使得这个括号序列合法。

思路:DP

dp[ i ][ j ]表示 区间[ i , j ] 变成合法需要加的最少括号数。

而,要求dp[ i ][ j ]有三种情况

(1) i==j : dp[ i ][ j ]=1 就是加上对应的括号

(2) ch[ i ] 和 ch[ j ] 不能配对 : min(dp[i][k]+dp[k+1][j]) for k=i,i+1,...,j-1

(3) ch[ i ] 和 ch[ j ] 能配对:

如果i+1==j    dp[i][j]=0;

否则 dp[i][j] = 将 dp[i+1][j-1]  与 (2) 中的情况相对比,求最小。

这就求出了数量。要显示出来,就DP的时候,同步记录操作。

op[ i ][ j ] = 0 :表示加上与这个括号对应的括号

op[ i ][ j ] =-1:表示ch[ i ] 与 ch[ j ] 是一对括号

op[ i ][ j ] =k>0: 表示分成两组:[ i , k ] 和 [ k+1 , j ]

然后最后递归输出就行了。


DP部分代码:

for(int i=n;i>0;--i){for(int j=i;j<=n;++j){if(i==j){dp[i][j]=1;op[i][j]=0;//0 means add the one that matchescontinue;}int K=i,ANS=dp[i][K]+dp[K+1][j];for(int k=K+1;k <j;++k){if(dp[i][k]+dp[k+1][j]<ANS){ANS=dp[i][k]+dp[k+1][j];K=k;}}dp[i][j]=ANS;op[i][j]=K;//positive value means to split at op[i][j] if(ch[i]=='['&&ch[j]==']'||ch[i]=='('&&ch[j]==')'){if(i+1==j){dp[i][j]=0;op[i][j]=-1;}else if(dp[i+1][j-1]<dp[i][j]) {dp[i][j]=dp[i+1][j-1];op[i][j]=-1;//-1 means ch[i] and ch[j] matches}}}
}

显示部分代码:

void Show(int i,int j){if(~op[i][j]){if(op[i][j]){//positive value : split at op[i][j]Show(i,op[i][j]);Show(op[i][j]+1,j);}else{//op[i][j]=0 :add the one that matchesif(ch[i]=='('||ch[i]==')') printf("()");else printf("[]");}}else{//op[i][j] = -1 :ch[i] and ch[j] matches printf("%c",ch[i]);if(i+1!=j) Show(i+1,j-1);printf("%c",ch[j]);}
}


这篇关于URAL 1183.Brackets Sequence ( DP+记录路径)的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/1092598

相关文章

SpringBoot3应用中集成和使用Spring Retry的实践记录

《SpringBoot3应用中集成和使用SpringRetry的实践记录》SpringRetry为SpringBoot3提供重试机制,支持注解和编程式两种方式,可配置重试策略与监听器,适用于临时性故... 目录1. 简介2. 环境准备3. 使用方式3.1 注解方式 基础使用自定义重试策略失败恢复机制注意事项

Python UV安装、升级、卸载详细步骤记录

《PythonUV安装、升级、卸载详细步骤记录》:本文主要介绍PythonUV安装、升级、卸载的详细步骤,uv是Astral推出的下一代Python包与项目管理器,主打单一可执行文件、极致性能... 目录安装检查升级设置自动补全卸载UV 命令总结 官方文档详见:https://docs.astral.sh/

SpringBoot项目配置logback-spring.xml屏蔽特定路径的日志

《SpringBoot项目配置logback-spring.xml屏蔽特定路径的日志》在SpringBoot项目中,使用logback-spring.xml配置屏蔽特定路径的日志有两种常用方式,文中的... 目录方案一:基础配置(直接关闭目标路径日志)方案二:结合 Spring Profile 按环境屏蔽关

统一返回JsonResult踩坑的记录

《统一返回JsonResult踩坑的记录》:本文主要介绍统一返回JsonResult踩坑的记录,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录统一返回jsonResult踩坑定义了一个统一返回类在使用时,JsonResult没有get/set方法时响应总结统一返回

Go学习记录之runtime包深入解析

《Go学习记录之runtime包深入解析》Go语言runtime包管理运行时环境,涵盖goroutine调度、内存分配、垃圾回收、类型信息等核心功能,:本文主要介绍Go学习记录之runtime包的... 目录前言:一、runtime包内容学习1、作用:① Goroutine和并发控制:② 垃圾回收:③ 栈和

java对接海康摄像头的完整步骤记录

《java对接海康摄像头的完整步骤记录》在Java中调用海康威视摄像头通常需要使用海康威视提供的SDK,下面这篇文章主要给大家介绍了关于java对接海康摄像头的完整步骤,文中通过代码介绍的非常详细,需... 目录一、开发环境准备二、实现Java调用设备接口(一)加载动态链接库(二)结构体、接口重定义1.类型

VSCode设置python SDK路径的实现步骤

《VSCode设置pythonSDK路径的实现步骤》本文主要介绍了VSCode设置pythonSDK路径的实现步骤,包括命令面板切换、settings.json配置、环境变量及虚拟环境处理,具有一定... 目录一、通过命令面板快速切换(推荐方法)二、通过 settings.json 配置(项目级/全局)三、

使用Python和Matplotlib实现可视化字体轮廓(从路径数据到矢量图形)

《使用Python和Matplotlib实现可视化字体轮廓(从路径数据到矢量图形)》字体设计和矢量图形处理是编程中一个有趣且实用的领域,通过Python的matplotlib库,我们可以轻松将字体轮廓... 目录背景知识字体轮廓的表示实现步骤1. 安装依赖库2. 准备数据3. 解析路径指令4. 绘制图形关键

apache的commons-pool2原理与使用实践记录

《apache的commons-pool2原理与使用实践记录》ApacheCommonsPool2是一个高效的对象池化框架,通过复用昂贵资源(如数据库连接、线程、网络连接)优化系统性能,这篇文章主... 目录一、核心原理与组件二、使用步骤详解(以数据库连接池为例)三、高级配置与优化四、典型应用场景五、注意事

SpringBoot实现文件记录日志及日志文件自动归档和压缩

《SpringBoot实现文件记录日志及日志文件自动归档和压缩》Logback是Java日志框架,通过Logger收集日志并经Appender输出至控制台、文件等,SpringBoot配置logbac... 目录1、什么是Logback2、SpringBoot实现文件记录日志,日志文件自动归档和压缩2.1、