【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的长方形去填格子的空缺; 如果有填满的方案且方案 ...
随机推荐
- ZooKeeper一二事 - 搭建ZooKeeper伪分布式及正式集群 提供集群服务
集群真是好好玩,最近一段时间天天搞集群,redis缓存服务集群啦,solr搜索服务集群啦,,,巴拉巴拉 今天说说zookeeper,之前搭建了一个redis集群,用了6台机子,有些朋友电脑跑步起来,有 ...
- maven 多工程搭建演示
maven出现后,很多公司会用maven来构建项目,单仅仅只是单项目单工程的 并没有使用多工程来构建,这样在以后,项目越来越大,业务越来越多以后,项目会难以维护,越发庞大,维护成本提高,团队士气也会下 ...
- 在A*寻路中使用二叉堆
接上篇:A*寻路初探 GameDev.net 在A*寻路中使用二叉堆 作者:Patrick Lester(2003年4月11日更新) 译者:Panic 2005年3月28日 译者序 这一篇文章,是&q ...
- java11-4 字符串的遍历以及字符串中各类字符的统计
1.需求:获取字符串中的每一个字符 分析: A:如何能够拿到每一个字符呢? char charAt(int index) B:我怎么知道字符到底有多少个呢? int length() publi ...
- Android 动态加载 (三) PAK 详解
pak文件经常出现于游戏的安装目录中,其实pak文件是一种特殊的游戏压缩文件,用于压缩声音.图片等资料.由于pak文件专门针对游戏设计文件结构,pak文件就是将多个文件(图片.音乐.文本)打包为一个单 ...
- 图像相似度算法的C#实现及测评
近日逛博客的时候偶然发现了一个有关图片相似度的Python算法实现.想着很有意思便搬到C#上来了,给大家看看. 闲言碎语 才疏学浅,只把计算图像相似度的一个基本算法的基本实现方式给罗列了出来,以至于在 ...
- JavaScript开发规范要求
http://www.cnblogs.com/webflash/archive/2010/06/11/1756255.html 作为一名开发人员(WEB前端JavaScript开发),不规范的开发不仅 ...
- Android 获取手机Mac地址,手机名称
/** * 获取手机mac地址<br/> * 错误返回12个0 */ public static String getMacAddress(Context context) { // 获取 ...
- 信息安全系统设计基础实验四:外设驱动程序设计 20135211李行之&20135216刘蔚然
北京电子科技学院(BESTI) 实 验 报 告 封面 课程:信息安全系统设计基础 班级:1352 ...
- 20135223/20135234/20135229小组——亚博 Arduino智能小车实践报告
实验名称:Arduino智能小车组装和综合测试 实验小组成员:20135223何伟钦 20135234马启扬 20135229吕松鸿 实验日期:2015.10.27—2015.11.3 实验时长:24 ...