[原]POJ1141 Brackets Sequence (dp动态规划,递归)
本文出自:http://blog.csdn.net/svitter
原题:http://poj.org/problem?id=1141
题意:输出添加括号最少,并且使其匹配的串。
题解: dp [ i ] [ j ] 表示添加括号的个数, pos[ i][ j ] 表示 i , j 中哪个位置分开,使得两部分分别匹配。
pos [ i ][ j ] 为-1的时候,说明i, j 括号匹配。
初始值置dp [ i ] [ i ] = 1; 如果只有一个括号,那么匹配结果必然是差1。
首先判断括号是否匹配,如果匹配,那么dp [ i ] [ j ] = dp[ i + 1] [ j - 1] 。如此递推dp [ i ] [ j ] 的值。
然后判断dp [ i ] [ j ] = min ( dp [ i ] [ mid ] + dp [ mid + 1 ] [ j ]);
for k = 1...len
for i = 0...i + k < len
求出dp[ i ] [ i + k ]每段。先求短区间,再求长区间,用短区间来求长区间。
可以说是http://blog.csdn.net/svitter/article/details/24877159的加强变种。
//注:除了多添加一个pos其他的一模一样。但是用当初的算法显然不符合此时的条件,只得作罢。后来借鉴了别人的代码,才推出。
再一个问题就是print_str(i , j)函数。按区间输出。、
//注:开始想到pos时,觉得没法输出放弃了,后来看到这个算法才算明白。
依据分段来输出,pos如果不为-1,那么需要从pos处分开输出。
如果pos为-1,那么输出首括号,输出中间部分,输出尾括号(两者是匹配的)
如果i == j , 如果括号为( | )则输出(), 如果括号为[ | ]则输出 [] 。
注意:必须用gets函数,因为输入数据中有空格,使用scanf函数中间会出问题。
AC代码:
//============================================================================
// Name : test.cpp
// Author :
// Version :
// Copyright : Your copyright notice
// Description : Hello World in C++, Ansi-style
//============================================================================
//============================================================================
// Name : 动态规划.cpp
// Author : blog.csdn.net/svitter
// Version :
// Copyright : Your copyright notice
// Description : Hello World in C++, Ansi-style
//============================================================================ #include <iostream>
#include <stdio.h>
#include <string.h> using namespace std;
#define MAXN 256
char br[MAXN];
int dp[MAXN][MAXN], pos[MAXN][MAXN];
int len; void print_br(int i, int j){
if(i > j)
return;
if(i == j){
if(br[i] =='(' || br[j] == ')')
printf("()");
else
printf("[]");
}
else if(pos[i][j] == -1){
printf("%c", br[i]);
print_br(i+1, j-1);
printf("%c", br[j]);
}
else{
print_br(i, pos[i][j]);
print_br(pos[i][j] + 1, j);
}
} bool match(int i, int j)
{
if(br[i] == '(' && br[j] == ')')
return true;
if(br[i] == '[' && br[j] == ']')
return true;
return false;
} int main() {
//work pit
int i, j, k, mid, t; while (gets(br) != NULL) {
memset(dp, 0, sizeof(dp)); len = strlen(br);
for (i = 0; i < len; i++)
dp[i][i] = 1; for (k = 1; k < len; k++) {
for(i = 0; i + k < len; i ++){
j = i + k;
dp[i][j] = 0x7fffffff;
if(match(i, j)){//如果当前位置匹配,那么pos置-1
dp[i][j] = dp[i+1][j-1] , pos[i][j] = -1;
}
for(mid = i; mid < j; mid++){
if(dp[i][j] > (t = dp[i][mid] + dp[mid+1][j])){//如果存在更优分解,那么选择更优分解
dp[i][j] = t, pos[i][j] = mid;
}
}
}
}
print_br(0, len - 1);
printf("\n");
} return 0;
}
[原]POJ1141 Brackets Sequence (dp动态规划,递归)的更多相关文章
- POJ1141 Brackets Sequence
Description Let us define a regular brackets sequence in the following way: 1. Empty sequence is a r ...
- 1626 - Brackets sequence——[动态规划]
Let us define a regular brackets sequence in the following way: Empty sequence is a regular sequence ...
- POJ 1141 Brackets Sequence(DP)
题目链接 很早 很早之前就看过的一题,今天终于A了.状态转移,还算好想,输出路径有些麻烦,搞了一个标记数组的,感觉不大对,一直wa,看到别人有写直接输出的..二了,直接输出就过了.. #include ...
- POJ 1141 Brackets Sequence (区间DP)
Description Let us define a regular brackets sequence in the following way: 1. Empty sequence is a r ...
- 区间DP POJ 1141 Brackets Sequence
Brackets Sequence Time Limit: 1000MS Memory Limit: 65536K Total Submissions: 29520 Accepted: 840 ...
- POJ 题目1141 Brackets Sequence(区间DP记录路径)
Brackets Sequence Time Limit: 1000MS Memory Limit: 65536K Total Submissions: 27793 Accepted: 788 ...
- 记忆化搜索(DP+DFS) URAL 1183 Brackets Sequence
题目传送门 /* 记忆化搜索(DP+DFS):dp[i][j] 表示第i到第j个字符,最少要加多少个括号 dp[x][x] = 1 一定要加一个括号:dp[x][y] = 0, x > y; 当 ...
- ZOJ1463:Brackets Sequence(间隙DP)
Let us define a regular brackets sequence in the following way: 1. Empty sequence is a regular seque ...
- poj 1141 Brackets Sequence 区间dp,分块记录
Brackets Sequence Time Limit: 1000MS Memory Limit: 65536K Total Submissions: 35049 Accepted: 101 ...
随机推荐
- MSSQL死锁产生原因及解决方法
一. 什么是死锁 死锁是指两个或两个以上的进程在执行过程中,因争夺资源而造成的一种互相等待的现象,若无外力作用,它们都将无法推进下去.此时称系统处于死锁状态或系统产生了死锁,这些永远在互相等的进 ...
- Shell中set用法(转载)
使用set命令可以设置各种shell选项或者列出shell变量. 单个选项设置常用的特性. 在某些选项之后-o参数将特殊特性打开. 在某些选项之后使用+o参数将关闭某些特性, 不带任何参数的set命令 ...
- tar.gz和rpm安装文件(转载)
from:http://bbs.chinaunix.net/thread-2277750-1-1.html Linux软件的二进制分发是指事先已经编译好二进制形式的软件包的发布形式,其优点是安装使用容 ...
- Intellij IDEA 使用Spring-boot-devTools无效解决办法
相信大部分使用Intellij的同学都会遇到这个问题,即使项目使用了spring-boot-devtools,修改了类或者html.js等,idea还是不会自动重启,非要手动去make一下或者重启, ...
- play framework (一)
Playframework--像玩一样编程, 传说中有了它,放个猴子在电脑前都会编程了! http://developer.51cto.com/art/201202/320053.htm http:/ ...
- CRM 2016 自定义lookup过滤
function preFilterLookup() { //终端业态 Xrm.Page.getControl("new_typeofoperationid").addPreSea ...
- nyoj 84 阶乘的0
点击打开链接 阶乘的0 时间限制:3000 ms | 内存限制:65535 KB 难度:3 描述 计算n!的十进制表示最后有多少个0 输入 第一行输入一个整数N表示测试数据的组数(1<=N& ...
- MySQL数据的主从复制、半同步复制和主主复制详解-转
一.MySQL复制概述 ⑴.MySQL数据的复制的基本介绍 目前MySQL数据库已经占去数据库市场上很大的份额,其一是由于MySQL数据的开源性和高性能,当然还有重要的一条就是免费~不过不知道还能免费 ...
- javascript 过滤字符串中的中文与空格
js 如何过滤字符串里中文或空格呢?方法有很多种,我们可以使用替换与正则表达式来实现,本文向大家介绍两个简单的例子,感兴趣的码农可以参考一下. 1.javascript过滤空格: function m ...
- 剑指Offer:面试题16——反转链表(java实现)
问题描述 定义一个函数,输入一个链表的头结点,反转该链表并输出反转后的链表的头结点.链表结点如下: public class ListNode { int val; ListNode next = n ...