【CodeForces 567F】Mausoleum
寒假最后一题补完啦 ^∀^
题意
1到n每个数字有两个,排成先不降后不升的序列,比如112332,并且满足k个形如 3 <= 6 代表第三个数字要≤第六个数字这样的约束要求,求有多少种排法。
分析
区间DP,dp[i][j]表示只有区间[i,j]还没填时的方案数。
b[i][j]表示第i和j位置的数字约束关系。
然后从两头开始排,每次把两个数字t放在两边或者同一边。
dp[i+1][j-1]+=dp[i][j];//放在两边
dp[i+2][j]+=dp[i][j];//放在左边
dp[i][j-2]+=dp[i][j];//放在右边
并且要满足约束条件。如果i位置小于j位置,那么必须先放i位置。
即放在当前位置上的数>(≥)已经放好的位置上的数,<(≤)未放置的位置上的数。
并且每次放的两个位置如果有约束关系,只能是含有=的(=、≥、≤)。
当j==i+1时,就只能一种放法了,这时候就可以累加答案了。
当我们放数字t时,区间[i,j]的长度是2*n-2*(t-1),所以j=i+2*n-2*(t-1)-1=2*n-2*t+i+1。
方案数比较大,所以要用long long。
代码
#include<cstdio>
#include<cstring>
#define ll long long
#define N 75
int n,k;
ll dp[N][N],ans;
int b[N][N];
//b[i][j] -2 -1 3 1 2
//i s j > >= = <= <
int ch(int fl,int fr,int a,int c)//现在排的位置上的数要比自由部分的小
{
for(int i=fl; i<=fr; i++)
if(b[a][i]==||b[c][i]==||b[a][i]<||b[c][i]<)return ;
return ;
}
int cc(int bl,int br,int a,int c){//现在排的位置上的数要比排好部分的大
for(int i=;i<=bl;i++)
if(b[a][i]>||b[c][i]>)return ;
for(int i=br;i<=*n;i++)
if(b[a][i]>||b[c][i]>)return ;
return ;
}
int check(int i,int j)//不可以放在两个数字不允许相同的位置上
{
return b[i][j]!=-&&b[i][j]!=;
}
int main()
{
scanf("%d%d",&n,&k);
for(int i=; i<=k; i++)
{
int l,r,f=;
char s[];
scanf("%d%s%d",&l,s,&r);
if(s[]=='<')
{
f=;
if(s[])f--;
}
else if(s[]=='>')
{
f=-;
if(s[])f++;
}
b[l][r]=f;
b[r][l]=f==?f:-f;
}
dp[][*n]=;
for(int t=; t<=n; t++)
for(int i=; i<=*t-; i++)
{
int j=*n-*t+i+;
if(dp[i][j])
{
if(j==i+)
{
if(check(i,j))
ans+=dp[i][j];
}
else
{
if(ch(i+,j-,i,j)&&cc(i-,j+,i,j)&&check(i,j))
dp[i+][j-]+=dp[i][j];
if(ch(i+,j,i,i+)&&cc(i-,j+,i,i+)&&check(i,i+))
dp[i+][j]+=dp[i][j];
if(ch(i,j-,j-,j)&&cc(i-,j+,j-,j)&&check(j-,j))
dp[i][j-]+=dp[i][j];
}
}
}
printf("%lld",ans);
return ;
}
【CodeForces 567F】Mausoleum的更多相关文章
- 【codeforces 415D】Mashmokh and ACM(普通dp)
		
[codeforces 415D]Mashmokh and ACM 题意:美丽数列定义:对于数列中的每一个i都满足:arr[i+1]%arr[i]==0 输入n,k(1<=n,k<=200 ...
 - 【codeforces 707E】Garlands
		
[题目链接]:http://codeforces.com/contest/707/problem/E [题意] 给你一个n*m的方阵; 里面有k个联通块; 这k个联通块,每个连通块里面都是灯; 给你q ...
 - 【codeforces 707C】Pythagorean Triples
		
[题目链接]:http://codeforces.com/contest/707/problem/C [题意] 给你一个数字n; 问你这个数字是不是某个三角形的一条边; 如果是让你输出另外两条边的大小 ...
 - 【codeforces 709D】Recover the String
		
[题目链接]:http://codeforces.com/problemset/problem/709/D [题意] 给你一个序列; 给出01子列和10子列和00子列以及11子列的个数; 然后让你输出 ...
 - 【codeforces 709B】Checkpoints
		
[题目链接]:http://codeforces.com/contest/709/problem/B [题意] 让你从起点开始走过n-1个点(至少n-1个) 问你最少走多远; [题解] 肯定不多走啊; ...
 - 【codeforces 709C】Letters Cyclic Shift
		
[题目链接]:http://codeforces.com/contest/709/problem/C [题意] 让你改变一个字符串的子集(连续的一段); ->这一段的每个字符的字母都变成之前的一 ...
 - 【Codeforces 429D】 Tricky Function
		
[题目链接] http://codeforces.com/problemset/problem/429/D [算法] 令Si = A1 + A2 + ... + Ai(A的前缀和) 则g(i,j) = ...
 - 【Codeforces 670C】 Cinema
		
[题目链接] http://codeforces.com/contest/670/problem/C [算法] 离散化 [代码] #include<bits/stdc++.h> using ...
 - 【codeforces 515D】Drazil and Tiles
		
[题目链接]:http://codeforces.com/contest/515/problem/D [题意] 给你一个n*m的格子; 然后让你用1*2的长方形去填格子的空缺; 如果有填满的方案且方案 ...
 
随机推荐
- vim支持lua
			
1. ncurses 安装 官网下载:http://ftp.gnu.org/pub/gnu/ncurses/ncurses-5.9.tar.gz CSDN 下载:http://download.csd ...
 - codeforces 709C C. Letters Cyclic Shift(贪心)
			
题目链接: C. Letters Cyclic Shift 题意: 现在一串小写的英文字符,每个字符可以变成它前边的字符即b-a,c-a,a-z这样,选一个字串变换,使得得到的字符串字典序最小; 思路 ...
 - POJ 3264 Balanced Lineup -- RMQ或线段树
			
一段区间的最值问题,用线段树或RMQ皆可.两种代码都贴上:又是空间换时间.. RMQ 解法:(8168KB 1625ms) #include <iostream> #include < ...
 - Ajax类库需要注意的问题
			
构建Ajax类库时,注意四步就可以了: 1:创建Ajax 对象 2:链接服务器 3:发送请求 4:返回响应 下面是我自己写的一个Ajax类库: function ajax(url,fnn,fai) ...
 - Android学习----自适应国际化语言
			
[前言] 自适应的知识与编程无关,关键在于配置文件的修改.自适应的内容包括:语言.屏幕.平台.今天就来说一下如何自适应国际化言. internationalization (国际化)简称:i18n,因 ...
 - 用Access作为后台数据库支撑,书写一个用C#写入记录的案例
			
具体的步骤: 1.创建并打开一个OleDbConnection对象 2.创建插入的SQL语句 3.创建一个OleDbCommand对象 4.使用OleDbCommand对象来插入数据 5.关闭OleD ...
 - HTTPWatch使用
			
注意:现在httpwatch也可以集成到火狐浏览器中. 一.介绍 HttpWatch是强大的网页数据分析工具.集成在Internet Explorer工具栏.包括网页摘要.Cookies管理.缓存管理 ...
 - 第三方登录之qq登录(转载)
			
iOS QQ第三方登实现 我们经常会见到应用登陆的时候会有QQ,微信,微博等的第三方登陆 如图: 下面我们主要讲一下qq的第三方登陆如何实现 首先,到官网注册: http://wiki.conne ...
 - JQuery demo
			
<!DOCTYPE HTML> <html> <head> <meta charset="utf-8"> <title> ...
 - javascript中的array对象属性及方法
			
Array 对象 Array 对象用于在单个的变量中存储多个值. 创建 Array 对象的语法: new Array(); new Array(size); new Array(element0, e ...