清北-Day6-regular
题目描述
给出一个只包含左括号和右括号的字符串,插入若干左右括号(可以插在任意位置)之后使得字符串长度为$ 2\times n $ 且是一个合法的括号序列。求最后能组成多少种不同的合法括号序列。
【合法的括号序列:该序列任意一个前缀的左括号数大于等于右括号数,最终左括号数等于右括号数】
输入
输入文件名为regular.in。
第一行一个数 \(n\)
第二行一个字符串(长度小于等于 $ 2\times n $ )
输出
输出文件名为regular.out。
输出一个数,表示答案 $ \pmod {10^9 + 7} $
样例输入
2
()
样例输出
2
提示
【数据说明】
对于50%的数据,$ 1 \le n \le 10 $
对于100%的数据,$ 1 \le n \le 100 $
这个题...从学术角度来看,不失为一道好题,但是从我个人感情角度来看,就是道破题,为什么?——题目具有迷惑性...导致我考虑错误的思路半天.....我一开始错误的思路就是把一共能有多少对括号算出来
然后用Catlan数求解,不过这个思路为什么错了,我还不是很清楚...
说说正解的思路吧——DP:
这里采用了三维, $ dp_{ i , j , k } $ 表示插入 $ i $ 个括号,使用了原来的 $ j $ 个括号,现在左括号比右括号多 $ k $ 个的方案数
看起来挺麻烦的是吧....确实挺麻烦,一共有四个状态转移方程——使用原序列的左括号,插入一个左括号,使用原序列的右括号,插入一个右括号,这分别是四个方程的意义
我们考虑,枚举三维状态进行转移
当我们当前有一个左括号时,我们就要采用前两种转移,枚举到一个位置并且不是末位的时候,我们当然可以选择使用一个原序列的左括号或者再插入一个左括号,显然这样一定合法
同理,当我们有一个右括号时,我们应该采用后两种转移,枚举到一个位置并且不是末位的时候,我们当然也可以选择使用一个原序列的右括号或者再插入一个右括号,显然这样也是合法的.
最后的答案自然是在 $ dp_{ i \times 2 - m , m , 0} $ 中了
代码如下:
#include <iostream>
#include <cstring>
#include <cstdlib>
#include <cstdio>
#define LL long long
const LL mod = 1e9 + 7 ;
LL dp[220][220][220],n,m;
char s[10000];
int main(){
	scanf ("%lld" , & n );
	scanf ("%s" , s );
	dp[0][0][0] = 1 ; m = strlen ( s ) ;
	register LL maxf = ( n << 1 ) - m ;
	for(int i = 0 ; i <= maxf ; ++ i)
		for (int j = 0 ; j <= m ; ++ j)
			for (int k = 0 ; k <= n ; ++ k){
				if ( s[j] == '(' && j < m )
					dp[ i ][ j + 1 ][ k + 1 ] = ( dp [ i ][ j ][ k ] + dp[ i ][ j + 1 ][ k + 1 ] ) % mod ;
				else dp[ i + 1 ][ j ][ k + 1 ] = ( dp [ i ][ j ][ k ] + dp[ i + 1 ][ j ][ k + 1 ] ) % mod ;
				if ( k ){
					if ( s[j] == ')' && j < m )
						dp[ i ][ j + 1 ][ k - 1 ] = ( dp [ i ][ j ][ k ] + dp[ i ][ j + 1 ][ k - 1 ] ) % mod ;
					else dp[ i + 1 ][ j ][ k - 1 ] = ( dp [ i ][ j ][ k ] + dp[ i + 1 ][ j ][ k - 1 ] ) % mod ;
				}
			}
	printf ("%lld\n" , dp[maxf][m][0] % mod );
	return 0;
}
												
											清北-Day6-regular的更多相关文章
- 清北Day4
		
版权声明:如需转载请标明出处,未得到本人许可请勿转载. 今天就可以看到传说中的 数据结构 嘿嘿嘿嘿 都有什么呢 链表 队列 栈 st表 hash 线段树 树链剖分 一.栈: 放出来这个看烂了的图 值得 ...
 - 清北学堂2017NOIP冬令营入学测试P4745 B’s problem(b)
		
清北学堂2017NOIP冬令营入学测试 P4745 B's problem(b) 时间: 1000ms / 空间: 655360KiB / Java类名: Main 背景 冬令营入学测试 描述 题目描 ...
 - 清北学堂2017NOIP冬令营入学测试 P4744 A’s problem(a)
		
清北学堂2017NOIP冬令营入学测试 P4744 A's problem(a) 时间: 1000ms / 空间: 655360KiB / Java类名: Main 背景 冬令营入学测试题,每三天结算 ...
 - 清北Day 2
		
清北第二天,感受到了来自这个世界的不友善,大概把没听过不会的"名词"记录下来就已经一面了,然后被大佬说这都是最基础的东西,就很皮,那就趁别人练习字符串的题的时候,来写波博客了,倒不 ...
 - 济南清北学堂游记 Day 1.
		
快住手!这根本不是暴力! 刷了一整天的题就是了..上午三道题的画风还算挺正常,估计是第一天,给点水题做做算了.. rqy大佬AK了上午的比赛! 当时我t2暴力写挂,还以为需要用啥奇怪的算法,后来发现, ...
 - 清明培训 清北学堂  DAY1
		
今天是李昊老师的讲授~~ 总结了一下今天的内容: 1.高精度算法 (1) 高精度加法 思路:模拟竖式运算 注意:进位 优化:压位 程序代码: #include<iostream>#in ...
 - 清北省选 DAY last  集锦
		
这是题目描述的链接: http://lifecraft-mc.com/wp-content/uploads/2018/03/problems1.pdf (虽然这次没去清北,但还是厚颜无耻的做了一下这套 ...
 - 2017.10.1 国庆清北 D1T1 zhx的字符串题
		
题目背景 2017国庆清北D1T1 题目描述 你是能看到第一题的 friends 呢. ——hja 何大爷对字符串十分有研究,于是天天出字符串题虐杀 zhx.何大爷今天为 字符串定义了新的权值计算方法 ...
 - 7月清北学堂培训 Day 3
		
今天是丁明朔老师的讲授~ 数据结构 绪论 下面是天天见的: 栈,队列: 堆: 并查集: 树状数组: 线段树: 平衡树: 下面是不常见的: 主席树: 树链剖分: 树套树: 下面是清北学堂课程表里的: S ...
 - 清北学堂模拟day6 兔子
		
[问题描述] 在一片草原上有N个兔子窝,每个窝里住着一只兔子,有M条路径连接这些窝.更特殊地是,至多只有一个兔子窝有3条或更多的路径与它相连,其它的兔子窝只有1条或2条路径与其相连.换句话讲,这些兔子 ...
 
随机推荐
- 毕业季,我的Linux求职之路
			
秋招终于告一段落了,本硕的七年求学之路也快画上了句号.回首求职的这一段日子,痛苦并快乐着.感谢所有陪伴着我走过这一段路程的同学,所有的辛酸都值得铭记.求职的过程中在网上看了很多的求职经验,现在想写一篇 ...
 - 一些有意思的Linux命令
			
1.输出你最常用的十条命令 history|awk '{print $2}'|awk 'BEGIN {FS="|"} {print $1}'|sort|uniq -c|sort - ...
 - JarvisOJ Misc shell流量分析
			
分析一下shell流量,得到flag 看着一大推的数据记录头都大了,并没有什么wireshark的使用经验,开始胡搞 首先用notepad++打开,搜索flag字样找到了一个类似于python脚本的东 ...
 - 雷军微博拧螺丝,CFO为粉丝数发愁
			
导读 小米集团联合创始人.品牌战略官黎万强4年前写的书<参与感>,估计又要热卖了. 3月24日,小米CFO周受资发微博,“我刚接受了同事的挑战,要在一定时间内在微博上有更多的粉丝”,并向粉 ...
 - bzoj4671: 异或图——斯特林反演
			
[BZOJ4671]异或图 - xjr01 - 博客园 考虑先算一些限制少的情况 gi表示把n个点的图,划分成i个连通块的方案数 连通块之间不连通很好处理(怎么处理看下边),但是内部必须连通,就很难办 ...
 - os.listdir()、os.walk()和os.mkdir()的用法
			
内容主要参照博客https://blog.csdn.net/xxn_723911/article/details/78795033 http://www.runoob.com/python/os-wa ...
 - Linux设备树(五 根节点)
			
五 根节点 一个最简单的设备树必须包含根节点,cpus节点,memory节点.根节点的名字及全路径都是“/”,至少需要包含model和compatible两个属性.model属性我们在属性那节已经说过 ...
 - C# 执行DOS命令和批处理
			
在项目开发中,有时候要处理一些文件,比如视频格式的转换,如果用C开发一套算法,再用C#调用,未免得不偿失!有时候调用现有的程序反而更加方便.今天就来说一下C#中如何调用外部程序,执行一些特殊任务. 这 ...
 - usb驱动程序小结(六)
			
title: usb驱动程序小结 tags: linux date: 2018/12/20/ 17:59:51 toc: true --- usb驱动程序小结 linux中为usb驱动也提供了一套总线 ...
 - javax.websocket.DeploymentException: Multiple Endpoints may not be deployed to the same path [/websocket/{sid}] : existing endpoint was class com.sanyi.qibaobusiness.framework.webSocket.WebSocketServe
			
报错: javax.websocket.DeploymentException: Multiple Endpoints may not be deployed to the same path [/w ...