题目

题目描述

今天,接触信息学不久的小\(A\)刚刚学习了卡特兰数。

卡特兰数的一个经典定义是,将\(n\)个数依次入栈,合法的出栈序列个数。

小\(A\)觉得这样的情况太平凡了。于是,他给出了\(m\)组限制,每个限制形如\((f_i,g_i)\),表示\(f_i\)不能在\(g_i\)之后出栈。

他想求出:在满足了这\(m\)组限制的前提下,共有多少个合法的出栈序列。他不喜欢大数,你只需要求出答案在模\(998244353\)意义下的值即可。

输入格式

输入第一行为两个非负整数,\(n\)、\(m\),含义题面已给出。

接下来\(m\)行,每行两个正整数,\((f,g)\) 表示一组限制。

输出格式

输出一行,为一个非负整数,表示你求得的答案 \(mod\space 998244353\)。

样例输入

3 1
2 3

样例输出

3

样例解释

可以验证\(\{1,2,3\}\),\(\{2,1,3\}\),\(\{2,3,1\}\)都是合乎条件的。

数据规模

\(编号\) \(分值\) \(n\) \(m\) \(特殊性质\)
\(1\) \(15\) \(\le 300\) \(= 0\)
\(2\) \(15\) \(\le 7\) \(\le 10\)
\(3\) \(15\) \(\le 100\) \(\le 50\)
\(4\) \(15\) \(\le 300\) \(保证所有的f_i相同\)
\(5\) \(20\) \(\le 300\) \(\le 300\)
\(6\) \(20\) \(\le 300\)

对于全部的数据,保证\(n\le 300\),\(m\le \frac{n(n-1)}{2}\),\(f_i、g_i \le n\)。

题解

题目大意:\(n\)个数以此入栈,问在满足\(m\)个形如\(f_i\)不能在\(g_i\)后出栈的限制的出栈序列数

45%

我们知道卡特兰数有个推导公式是\(f_i=\sum_{i=1}^nf_i\times f_{n-i-1}\),这个公式实际上是枚举了最后出栈的数

那么扩展到这题,我们将\(dp\)转换为区间\(dp\),枚举\(k\)为最后出栈的数,那么有两种情况不合法:\(f=k\)或者\(f>k>g\)。当\(f=k\)的时候,\(f\)是最后出栈的,显然不合法。而我们知道,小于\(k\)总是比大于\(k\)的先出栈,所以当\(f>k>g\)时也是不合法的

设\(f[i][j]\)表示\(i\)到\(j\)这个区间的合法出栈序列,那么在上述两种不合法的情况不成立的情况下,\(f[i][j]+=f[i][k-1]\times f[k+1][j]\)

时间复杂度\(O(n^3m)\),预计得分\(45\)

100%

考虑优化\(dp\),在\(O(1)\)的时间内判断合不合法。不合法条件\(f>k>g\)成立,说明\(f>g\),那么在读入时\(f>g\)的放入平面直角坐标系中,坐标\((f,g)\),那么可以前缀和优化

记录前缀和\(sm[i][j]\)和\(l[i][j]\),分别记录\(f>g\)以及所有的点,用来判断\(f>k>g\)和\(f=k\)的情况

构造一个矩形

其中\(i,j,k\)分别是区间起点,终点,以及最后出栈的数

\(f=k\)说明\(l[k][j]-l[k][i-1]>0\),而如果矩形\(sm(i,i,j,k-1)-sm(i,i,k,j)>0\),说明有\(f>k>g\)的情况,这两种情况都是不合法的

这样的话时间复杂度优化到了\(O(n^3)\),预计得分\(100\)

Code

#include<cstdio>
#define mod 998244353
#define N 310
#define ll long long
using namespace std;
ll n,m,f[N][N],sm[N][N],al[N][N];
ll get(ll x,ll y,ll p,ll q) {return sm[x][y]-sm[x][q-1]-sm[p-1][y]+sm[p-1][q-1];}
int main()
{
freopen("catalan.in","r",stdin);
freopen("catalan.out","w",stdout);
scanf("%lld%lld",&n,&m);
for (ll i=1,x,y;i<=m;++i)
{
scanf("%lld%lld",&x,&y);
if (x!=y)
{
if (x>y) ++sm[x][y];
++al[x][y];
}
}
for (ll i=1;i<=n;++i)
for (ll j=1;j<=n;++j)
{
sm[i][j]=sm[i][j]+sm[i-1][j]+sm[i][j-1]-sm[i-1][j-1];
al[i][j]=al[i][j]+al[i][j-1];
}
for (ll i=1;i<=n;++i)
f[i][i]=f[i+1][i]=f[i][i-1]=1;
for (ll len=2;len<=n;++len)
for (ll i=1;i+len-1<=n;++i)
{
ll j=i+len-1;
for (ll k=i;k<=j;++k)
{
ll x;
if (k>i) x=get(j,k-1,i,i)-get(k,j,i,i);
else x=0;
ll y=al[k][j]-al[k][i-1];
if (x<=0&&y<=0) f[i][j]=(f[i][j]+f[i][k-1]*f[k+1][j]%mod)%mod;
}
}
printf("%lld\n",f[1][n]);
fclose(stdin);
fclose(stdout);
return 0;
}

【2020.12.01提高组模拟】卡特兰数(catalan)的更多相关文章

  1. 【2020.12.01提高组模拟】A组反思

    105,rk45 T1 赛时一开始先打了\(m=0\)的情况,也就是普通的卡特兰数,然后打了暴力,样例过了,把样例改改就不行了,原因没有保证是枚举的是合法的出栈序列 得分:\(WA\&TLE1 ...

  2. 【2020.12.02提高组模拟】球员(player)

    题目 题目描述 老师们已经知道学生喜欢睡觉,Soaring是这项记录保持者.他只会在吃饭或玩FIFA20时才会醒来.因此,他经常做关于足球的梦,在他最近的一次梦中,他发现自己成了皇家马德里足球俱乐部的 ...

  3. 【2020.12.03提高组模拟】A组反思

    估计:40+10+0+0=50 实际:40+10+0+0=50 rank40 T1 赛时看到\(n,m\leq9\),我当机立断决定打表,暴力打了几个点之后发现在\(n\ne m\)且\(k\ne0\ ...

  4. 【2020.12.02提高组模拟】A组反思

    55,rk47 T1 赛时先想了\(trie\),想到不一定是前缀,然后就放弃转为打暴力 得分:\(RE22\) 正解是只用判断\(i\)与\(i+1\)的关系,那么只有两种情况,判断一下然后\(dp ...

  5. 【2020.11.28提高组模拟】T1染色(color)

    [2020.11.28提高组模拟]T1染色(color) 题目 题目描述 给定 \(n\),你现在需要给整数 \(1\) 到 \(n\) 进行染色,使得对于所有的 \(1\leq i<j\leq ...

  6. 【2020.11.28提高组模拟】T2 序列(array)

    序列(array) 题目描述 ​给定一个长为 \(m\) 的序列 \(a\). 有一个长为 \(m\) 的序列 \(b\),需满足 \(0\leq b_i \leq n\),\(\sum_{i=1}^ ...

  7. 【2020.11.30提高组模拟】剪辣椒(chilli)

    剪辣椒(chilli) 题目描述 在花园里劳累了一上午之后,你决定用自己种的干辣椒奖励自己. 你有n个辣椒,这些辣椒用n-1条绳子连接在一起,任意两个辣椒通过用若干个绳子相连,即形成一棵树. 你决定分 ...

  8. 【2020.11.30提高组模拟】删边(delete)

    删边(delete) 题目 题目描述 给你一棵n个结点的树,每个结点有一个权值,删除一条边的费用为该边连接的两个子树中结点权值最大值之和.现要删除树中的所有边,删除边的顺序可以任意设定,请计算出所有方 ...

  9. JZOJ 5184. 【NOIP2017提高组模拟6.29】Gift

    5184. [NOIP2017提高组模拟6.29]Gift (Standard IO) Time Limits: 1000 ms  Memory Limits: 262144 KB  Detailed ...

随机推荐

  1. .net 实现之短信验证码

    接口类型:互亿无线触发短信接口,支持发送验证码短信.订单通知短信等. 账户注册:请通过该地址开通账户http://sms.ihuyi.com/register.html 只能测试用: 实现注册页面 & ...

  2. leetcode6:binary-tree-postorder-traversal

    题目描述 求给定的二叉树的后序遍历. 例如: 给定的二叉树为{1,#,2,3}, 1↵ ↵ 2↵ /↵ 3↵ 返回[3,2,1]. 备注:用递归来解这道题太没有新意了,可以给出迭代的解法么? Give ...

  3. Aps.Net Core3.1 WebApi发送阿里云短信验证码

    1.前言 转眼又要过了一年了 好久没写博客了,人不学就要落后,今天有时间把以前弄的发送阿里云短信验证码登录记录一下. 2.准备条件 1)去阿里云官网注册一个账号.有账号直接登录就行,以前新人好像有免费 ...

  4. 对ESP8266的例子进行编译时报错check_python_dependencies的问题的解决

    尝试对ESP8266的例子进行编译时报错: make: *** 没有规则可制作目标"check_python_dependencies" 解决方法: 1.安装python pip包 ...

  5. 强迫自己学Jquery

    Jquery 适合我吗? 里面有很多用不上的功能, 我需要什么,常用的判断,常用的扩展,来自Dojo的Hitch函数,事件绑定,样式处理(添加 删除 替换),Ajax,模块加载, 足够了,真心不想用这 ...

  6. 利用.NET 5和Github Action 自动执行米游社原神每日签到福利

    背景 众所周知,原神的签到福利是需要下载app才可以领取的.但像我这种一般不怎么刷论坛的人,每天点开app签到很麻烦. 很多大佬利用Github的Action自动执行的模式,实现了很多好东西.加上.n ...

  7. http 响应 ngx_http_send_header ngx_http_output_filter

    在解析完  http 请求报文后, 需要发出响应报文, 那么ngx 框架 提供了那些通用接口呢?如果自己设计将所用的模块的响应接口合并起来 你会怎么设计呢?? 响应头过滤函数主要的用处就是处理HTTP ...

  8. 微服务下的持续集成-Jenkins自动化部署GitHub项目

    @ 目录 一.前言 二.DevOps概念 三.为什么要做持续集成 四.常见云服务 五.手动部署Jenkins 5.1 准备工作 5.2 下载 5.3 启动 5.4 配置 5.5 Jenkins 首页 ...

  9. MediaCodec编码OpenGL速度和清晰度均衡

      ## 概述 在安卓平台为了实现h264视频编码,我们通常可以使用libx264, ffmpeg等第三方视频编码库,但是如果对编码的速度有一定的要求,要实现实时甚至超实时的高速视频编码,我们并没有太 ...

  10. PHP 使用gd库压缩图片并生成新图片返回全路径

    使用gd库前,先检查是否开启了gd库 phpinfo(); 如果在php配置信息里找到了gd库,那么就是开启了,没开启的自行百度如何开启php gd库 既然开启了gd库,那么直接再php里写入以下代码 ...