CF567F/51nod2522 上下序列
CF567F/51nod2522 上下序列
考虑没有限制怎么做呢,就是从小往大加数,记录加到哪个数了还有左边有多少个数,然后这个数有两个,只能是左边放两个、右边放两个、左右各放一个。(实际上就是1,1,...,n-1,n-1的不下降子序列个数。。。)
然后有限制了,只要在转移的时候顺便判一下就行了。如下:现在要放i了,然后已经放好的是[1,l),(r,n]
--------------------l---------------------------r-----------------
<i i >i i <i
注意放n的时候实际上只有一种放法但是这里dp的时候会放3种,所以最后答案除以3
f[i][j]表示现在放数i,左边放了j个数的方案数
#include<bits/stdc++.h>
#define il inline
#define vd void
#define ll long long
il int gi(){
int x=0,f=1;
char ch=getchar();
while(ch<'0'||ch>'9'){if(ch=='-')f=-1;ch=getchar();}
while(ch>='0'&&ch<='9')x=x*10+ch-'0',ch=getchar();
return x*f;
}
int n,k;
ll f[37][71];
std::vector<int>a[71],b[71];
int main(){
freopen("1522.in","r",stdin);
freopen("1522.out","w",stdout);
n=gi(),k=gi();
char opt[3];int x,y,p;
for(int i=1;i<=k;++i){
scanf("%d%s%d",&x,opt,&y);
if(opt[0]=='=')p=0;
else if(opt[0]=='<'&&opt[1]=='\0')p=1;
else if(opt[0]=='<'&&opt[1]=='=' )p=2;
else if(opt[0]=='>'&&opt[1]=='\0')p=-1;
else if(opt[0]=='>'&&opt[1]=='=' )p=-2;
else puts("wrong answer!");
a[x].push_back(y),b[x].push_back(p);
a[y].push_back(x),b[y].push_back(-p);
}
f[1][0]=1;
for(int i=1;i<=n;++i)
for(int j=0;j<=(i-1)*2;++j){
int l=j+1,r=j+(n-i+1)*2;
for(int s=0;s<a[l].size();++s){
int A=a[l][s],B=b[l][s];
if((A<l||A>r)&&B>=0)goto GG1;
if((A>l+1&&A<=r)&&B<=0)goto GG1;
if((A==l||A==l+1)&&(B==1||B==-1))goto GG1;
}
for(int s=0;s<a[l+1].size();++s){
int A=a[l+1][s],B=b[l+1][s];
if((A<l||A>r)&&B>=0)goto GG1;
if((A>l+1&&A<=r)&&B<=0)goto GG1;
if((A==l||A==l+1)&&(B==1||B==-1))goto GG1;
}
f[i+1][j+2]+=f[i][j];
GG1:;
for(int s=0;s<a[r].size();++s){
int A=a[r][s],B=b[r][s];
if((A<l||A>r)&&B>=0)goto GG2;
if((A>=l&&A<r-1)&&B<=0)goto GG2;
if((A==r||A==r-1)&&(B==1||B==-1))goto GG2;
}
for(int s=0;s<a[r-1].size();++s){
int A=a[r-1][s],B=b[r-1][s];
if((A<l||A>r)&&B>=0)goto GG2;
if((A>=l&&A<r-1)&&B<=0)goto GG2;
if((A==r||A==r-1)&&(B==1||B==-1))goto GG2;
}
f[i+1][j]+=f[i][j];
GG2:;
for(int s=0;s<a[l].size();++s){
int A=a[l][s],B=b[l][s];
if((A<l||A>r)&&B>=0)goto GG3;
if((A>l&&A<r)&&B<=0)goto GG3;
if((A==l||A==r)&&(B==1||B==-1))goto GG3;
}
for(int s=0;s<a[r].size();++s){
int A=a[r][s],B=b[r][s];
if((A<l||A>r)&&B>=0)goto GG3;
if((A>l&&A<r)&&B<=0)goto GG3;
if((A==l||A==r)&&(B==1||B==-1))goto GG3;
}
f[i+1][j+1]+=f[i][j];
GG3:;
}
ll ans=0;for(int i=0;i<=n*2;++i)ans+=f[n+1][i];
printf("%lld\n",ans/3);
return 0;
}
CF567F/51nod2522 上下序列的更多相关文章
- 51NOD1522 上下序列/CF567F Mausoleum DP
题目传送门:http://codeforces.com/problemset/problem/567/F 大致题意:你有$1$到$N$的所有正整数每个数两个,现在需要你将它排成一个序列,使得序列为单峰 ...
- 【夯实PHP基础】UML序列图总结
原文地址 序列图主要用于展示对象之间交互的顺序. 序列图将交互关系表示为一个二维图.纵向是时间轴,时间沿竖线向下延伸.横向轴代表了在协作中各独立对象的类元角色.类元角色用生命线表示.当对象存在时,角色 ...
- Windows10-UWP中设备序列显示不同XAML的三种方式[3]
阅读目录: 概述 DeviceFamily-Type文件夹 DeviceFamily-Type扩展 InitializeComponent重载 结论 概述 Windows10-UWP(Universa ...
- 软件工程里的UML序列图的概念和总结
俗话说,自己写的代码,6个月后也是别人的代码……复习!复习!复习! 软件工程的一般开发过程:愿景分析.业务建模,需求分析,健壮性设计,关键设计,最终设计,实现…… 时序图也叫序列图(交互图),属于软件 ...
- python序列,字典备忘
初识python备忘: 序列:列表,字符串,元组len(d),d[id],del d[id],data in d函数:cmp(x,y),len(seq),list(seq)根据字符串创建列表,max( ...
- BZOJ 1251: 序列终结者 [splay]
1251: 序列终结者 Time Limit: 20 Sec Memory Limit: 162 MBSubmit: 3778 Solved: 1583[Submit][Status][Discu ...
- 最长不下降序列nlogn算法
显然n方算法在比赛中是没有什么用的(不会这么容易就过的),所以nlogn的算法尤为重要. 分析: 开2个数组,一个a记原数,f[k]表示长度为f的不下降子序列末尾元素的最小值,tot表示当前已知的最长 ...
- [LeetCode] Sequence Reconstruction 序列重建
Check whether the original sequence org can be uniquely reconstructed from the sequences in seqs. Th ...
- [LeetCode] Binary Tree Longest Consecutive Sequence 二叉树最长连续序列
Given a binary tree, find the length of the longest consecutive sequence path. The path refers to an ...
随机推荐
- UITabBar设置详解
UITabBar设置详解 效果图 说明 1. 设置tabBarItem中的图片以及标题 2. 设置标题文本样式 3. 修改tabBar背景色 源码 https://github.com/YouXian ...
- 全自动LTI部署OS
全自动LTI部署OS:零.通过ADK制作WinPE(需包含有imagex.exe工具,用来捕获映像)一.使用WinPE中的imagex捕获映像(install.wim)二.使用MDT制作启动映像(bo ...
- Ubuntu16.04安装redis和php的redis扩展
安装redis服务 sudo apt-get install redis-server 装好之后默认就是自启动.后台运行的,无需过多设置,安装目录应该是 /etc/redis 启动 sudo ser ...
- 【Excel】坐下,VLOOKUP基本操作
坐下,VLOOKUP基本操作 VLOOKUP如何使用我就不在这里详细介绍了,简单说一下好了. 如上图,第一个填写你要查找的值,第二个空选取你查找的范围,第三个空填你要得到第几列的值,最后选 ...
- taskset
常常感觉系统资源不够用,一台机子上跑了不下3个比较重要的服务,但是每天我们还要在上面进行个备份压缩等处理,网络长时间传输,这在就很影响本就不够用的系统资源: 这个时候我们就可以把一些不太重要的比如co ...
- 随手练——Uva-11584 划分成回文串(区间DP)
思路:dp[i]代表到第i位的最小值,枚举它的前几位,求出最小值. 转移方程:dp[ i ] = min(dp[ i ], dp[ j - 1 ] + 1 ) ; 本来觉得,代码加深部分可以提前bre ...
- [翻译]怎么写一个React组件库(一)
本文同步发布于知乎专栏 https://zhuanlan.zhihu.com/p/27401329,喜欢本文的就去知乎点个赞支持下吧- 引言 该系列文章将通过创建一个组件库来引导你学习如何构建自己的组 ...
- msf后渗透
生成exe后门 msfvenom -p windows/meterpreter/reverse_tcp lhost=192.168.31.131 lport=4444 -f exe -o 4444.e ...
- js对LocalDateTime时间的格式化成yyyy-MM-dd HH:mm:ss
formatter: function(value,row,index){ var arr = value; if(arr==null || arr==""){ return &q ...
- P2467 [SDOI2010]地精部落
题目描述 传说很久以前,大地上居住着一种神秘的生物:地精. 地精喜欢住在连绵不绝的山脉中.具体地说,一座长度为N的山脉H可分为从左到右的N段,每段有一个独一无二的高度Hi,其中Hi是1到N之间的正整数 ...