Brackets sequence UVA - 1626 (典型的区间dp+递归打印路径)

2024-04-29 13:32

本文主要是介绍Brackets sequence UVA - 1626 (典型的区间dp+递归打印路径),希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

点击链接哦:https://vjudge.net/problem/51187/origin

题目大意:括弧的序列,在一个字符串中只包含" ( " " ) "和“ [ ” “ ] ”,要求空序列为正确的括弧,如果s是正确的序列,那么[s]和(s)也是正确的序列,如果a和b是是正确的序列,那么ab也是正确的序列。

求在给出的字符串基础上要至少添加多少括号才能使得字符序列是正确的。

ps:紫书p278

一开始自己先是用模拟去做的,自己感觉应该能可以模拟出来,而且长度为100也不会超时。但还是考虑的情况太少了,最终再无数的debug中把这个方法给pass掉,还是看了一下紫书的讲解。对于菜鸟的我在短时间内把这个题想到用dp,而且解决确实有点难度。看到转移方程时感觉就是通过题意把情况给遍历一遍一样。但是自己却没想到。

既然是区间dp,那么肯定是二维的了 设dp[i][j]表示至少需要增加的括号个数。

那么在区间i~j上,如果s[i]和s[j]匹配的话,那么最少增加的括号个数就是区间i+1~j-1上的了,那么如果不匹配的话,那就应该是有两个正确的序列组合而成,如果在区间i~j上有一个k,正确的序列是由dp[i][k]+dp[k+1][j]而来,(其实这只是构成正确序列的一种办法,还有其他的办法也能构成最少的正确的序列)。边界:当序列为空时dp[][]=0;当序列只有一个字符是,那么肯定要补上一个,显然dp[i][i]=1;然后用递推求出。在这里有一个关键,就是当s[i]和s[j]匹配的话,还需要通过第二种方案更新吗?如果不同动脑子的话我想为了保险需要比较一下看看能不能更优化。然而书上也是强调必须要在第二种方案上在比较更新一下。比如有序列" [ ] [ ] ",显然左右是匹配的,那么会得到序列“ ] [ ”,显然要多加两个括号,不合情理。

另一个重点就是打印,仍然是递归打印,具体看代码吧;

坑点:注意输入and输出

///典型的区间DP
#include <iostream>
#include <bits/stdc++.h>using namespace std;
string s;
int dp[111][111];
int match(char a,char b)
{if(a=='('&&b==')')return 1;if(a=='['&&b==']')return 1;return 0;
}
void print(int i,int j)
{if(i>j)return ;if(i==j){if(s[i]=='('||s[j]==')')printf("()");else printf("[]");return ;}int ans=dp[i][j];if(match(s[i],s[j])&&ans==dp[i+1][j-1]){printf("%c",s[i]);print(i+1,j-1);printf("%c",s[j]);return ;}for(int k=i;k<j;k++){if(ans==dp[i][k]+dp[k+1][j]){print(i,k);print(k+1,j);return ;}}
}
int main()
{int t;scanf("%d",&t);getchar();while(t--){getchar();getline(cin,s);int n=s.size();for(int i=0;i<n;i++){dp[i+1][i]=0;dp[i][i]=1;}for(int i=n-2;i>=0;i--){for(int j=i+1;j<n;j++){dp[i][j]=n;if(match(s[i],s[j]))dp[i][j]=min(dp[i][j],dp[i+1][j-1]);for(int k=i;k<j;k++){dp[i][j]=min(dp[i][j],dp[i][k]+dp[k+1][j]);}}}print(0,n-1);printf("\n");if(t)printf("\n");}return 0;
}


这篇关于Brackets sequence UVA - 1626 (典型的区间dp+递归打印路径)的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



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

相关文章

利用Python把路径转为绝对路径的方法

《利用Python把路径转为绝对路径的方法》在Python中,如果你有一个相对路径并且想将其转换为绝对路径,你可以使用Path对象的resolve()方法,Path是Python标准库pathlib中... 目录1. os.path.abspath 是什么?怎么用?基本用法2. os.path.abspat

python获取指定名字的程序的文件路径的两种方法

《python获取指定名字的程序的文件路径的两种方法》本文主要介绍了python获取指定名字的程序的文件路径的两种方法,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要... 最近在做项目,需要用到给定一个程序名字就可以自动获取到这个程序在Windows系统下的绝对路径,以下

深度解析Python中递归下降解析器的原理与实现

《深度解析Python中递归下降解析器的原理与实现》在编译器设计、配置文件处理和数据转换领域,递归下降解析器是最常用且最直观的解析技术,本文将详细介绍递归下降解析器的原理与实现,感兴趣的小伙伴可以跟随... 目录引言:解析器的核心价值一、递归下降解析器基础1.1 核心概念解析1.2 基本架构二、简单算术表达

SpringBoot路径映射配置的实现步骤

《SpringBoot路径映射配置的实现步骤》本文介绍了如何在SpringBoot项目中配置路径映射,使得除static目录外的资源可被访问,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一... 目录SpringBoot路径映射补:springboot 配置虚拟路径映射 @RequestMapp

Python lambda函数(匿名函数)、参数类型与递归全解析

《Pythonlambda函数(匿名函数)、参数类型与递归全解析》本文详解Python中lambda匿名函数、灵活参数类型和递归函数三大进阶特性,分别介绍其定义、应用场景及注意事项,助力编写简洁高效... 目录一、lambda 匿名函数:简洁的单行函数1. lambda 的定义与基本用法2. lambda

python设置环境变量路径实现过程

《python设置环境变量路径实现过程》本文介绍设置Python路径的多种方法:临时设置(Windows用`set`,Linux/macOS用`export`)、永久设置(系统属性或shell配置文件... 目录设置python路径的方法临时设置环境变量(适用于当前会话)永久设置环境变量(Windows系统

Java实现预览与打印功能详解

《Java实现预览与打印功能详解》在Java中,打印功能主要依赖java.awt.print包,该包提供了与打印相关的一些关键类,比如PrinterJob和PageFormat,它们构成... 目录Java 打印系统概述打印预览与设置使用 PageFormat 和 PrinterJob 类设置页面格式与纸张

Spring Boot中的路径变量示例详解

《SpringBoot中的路径变量示例详解》SpringBoot中PathVariable通过@PathVariable注解实现URL参数与方法参数绑定,支持多参数接收、类型转换、可选参数、默认值及... 目录一. 基本用法与参数映射1.路径定义2.参数绑定&nhttp://www.chinasem.cnbs

Python打印对象所有属性和值的方法小结

《Python打印对象所有属性和值的方法小结》在Python开发过程中,调试代码时经常需要查看对象的当前状态,也就是对象的所有属性和对应的值,然而,Python并没有像PHP的print_r那样直接提... 目录python中打印对象所有属性和值的方法实现步骤1. 使用vars()和pprint()2. 使

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

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