「BZOJ1485」[HNOI2009] 有趣的数列 (卡特兰数列)

BZOJ1485[HNOI2009] 有趣的数列

 

Description

 我们称一个长度为2n的数列是有趣的,当且仅当该数列满足以下三个条件:

   (1)它是从1到2n共2n个整数的一个排列{ai};

   (2)所有的奇数项满足a1<a3<…<a2n-1,所有的偶数项满足a2<a4<…<a2n

   (3)任意相邻的两项a2i-1与a2i(1≤i≤n)满足奇数项小于偶数项,即:a2i-1<a2i

   现在的任务是:对于给定的n,请求出有多少个不同的长度为2n的有趣的数列。因为最后的答案可能很大,所以只要求输出答案 mod P的值。

 

Input

输入文件只包含用空格隔开的两个整数n和P。输入数据保证,50%的数据满足n≤1000,100%的数据满足n≤1000000且P≤1000000000。

 

Output

仅含一个整数,表示不同的长度为2n的有趣的数列个数mod P的值。

 

Sample Input

3 10

 

Sample Output

5

 

对应的5个有趣的数列分别为(1,2,3,4,5,6),(1,2,3,5,4,6),(1,3,2,4,5,6),(1,3,2,5,4,6),(1,4,2,5,3,6)。

 

题解

 

对于 A4 来说 它一定大于前三个

对于 A3 来说 它一定小于后五个

所以可以推断 AI <2*i

可以容易得到一个n^2的dp

f[i][j]表示前i位填到数字j的方案,即第i位用的是j

f[i][j]=f[i][j-1]+f[i-1][j-1] (j<=2*i-1)

f[i][j]=f[i][j-1] (j>2*i-1)

输出前几项,发现是个卡特兰数列  F(n)=C(2*n,n)/(n+1)

分解质因数求即可

至于为什么是卡特兰数列?其实就是从左往右扫每个数,把放在奇数项看作入栈,偶数看作出栈

 

50 分 dp

#include<bits/stdc++.h>
using namespace std;
int n,mod;
int f[1005][2005];
int main(){scanf("%d%d",&n,&mod);for(int i=0;i<=2*n;i++) f[0][i]=1;for(int i=1;i<=n;i++)for(int j=1;j<=2*n;j++)if (j<=2*i-1) f[i][j]=(f[i][j-1]+f[i-1][j-1])%mod;else f[i][j]=f[i][j-1]%mod;printf("%d\n",f[n][2*n]);return 0;
}

 

 100 分 卡特兰

#include<bits/stdc++.h>
using namespace std;
typedef long long ll;
const int MAXN=1e6+5;
ll pri[MAXN],mn[MAXN*2],num[MAXN*2],ans=1;
int n,mod,cnt;
bool use[MAXN*2];
void getpri(){for (int i=2;i<=2*n;i++){if (!use[i]) pri[++cnt]=i,mn[i]=cnt;for (int j=1;pri[j]*i<=2*n&&j<=cnt;j++){use[pri[j]*i]=1,mn[pri[j]*i]=j;if (i%pri[j]==0) break;}}
}
void add(int x,int f){while (x!=1){num[mn[x]]+=f;x/=pri[mn[x]];}
}
int main(){scanf("%d%d",&n,&mod);getpri();for (int i=2*n;i>n;i--) add(i,1);for (int i=1;i<=n;i++) add(i,-1);add(n+1,-1);for (int i=1;i<=cnt;i++) while (num[i]--) ans=(ans*pri[i])%mod;printf("%lld\n",ans);return 0;
}

 

转载于:https://www.cnblogs.com/shjrd-dlb/p/9048894.html

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/397945.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

wedo2.0编程模块介绍_能量黑科技模块系列十:RFID魔块

RFID魔块RFID此模块可以对套件配套的RFID卡或者空白RFID卡进行读写&#xff0c;用于权限验证的DIY制作。常规的公交卡、地铁卡是无法进行写入&#xff0c;但可以读取UID号。配套RFID卡内存为1K&#xff0c;有16个分区&#xff0c;每个分区有3个数据块可进行写入此模块可以对套件…

Android 6.0权限问题

Android 6.0 open failed: EACCES (Permission denied) 对于6.0权限问题&#xff0c;报错如上&#xff1a; 解决方案&#xff1a; Android 6.0 (Marshmallow). 添加新的权限模型&#xff0c;需要在运行时动态获取所需要的权限。 首先判断手机系统版本是否在6.0然后才是支持运行…

[SoapUI] 通过SoapUI发送POST请求,请求的body是JSON格式的数据

通过SoapUI发送POST请求&#xff0c;请求的body是JSON格式的数据&#xff1a; data{"currentDate":"2015-06-19","reset":true} 而且通过Fiddler抓取页面报文 Content-Type 是 application/x-www-form-urlencoded 一开始我将Content-Type appl…

oracle -239报错,解决: ./check_oracle_health --connect orcl --mode connection-time 报错的问题...

错误提示./check_oracle_health --connect orcl --mode connection-timeCRITICAL - cannot connect to orcl. install_driver(Oracle) failed: Cant locate DBD/Oracle.pm in INC (INC contains: . /usr/local/lib64/perl5 /usr/local/share/perl5 /usr/lib64/perl5/vendor_per…

【python 3.6】调用另一个文件的类的方法

文件1&#xff1a;test12.py 文件2&#xff1a;test13.py 文件1 如下&#xff1a; #!/usr/bin/python # -*- coding: utf-8 -*-class abcd(object):def __init__(self):passdef pr(self):return("KKKKKKK") if __name__"__main__":abcd().pr() 文件2&#…

el-button 图标显示在字后边_Excel和Visio联姻,自动生成跨职能流程图,还能用图标标记状态,太牛了!...

正文共&#xff1a;1332 字 21 图预计阅读时间&#xff1a; 4 分钟Visio是Office软件系列中的负责绘制流程图和示意图的软件&#xff0c;创建具有专业外观的Visio图表&#xff0c;以便用户更好地理解和分析。企业管理中&#xff0c;业务流程在不同部门间流转&#xff0c;涉及提…

mybatisGenerator 代码自动生成报错 Result Maps collection already contains value for BaseResultMap...

由于mybatis简单易学&#xff0c;比起Hibername来&#xff0c;更容易上手&#xff0c;代码也能自动生成。这几天研究了下代码自动生成的&#xff0c;参考&#xff1a;http://0609xiaohua.iteye.com/blog/1453570但是把代码复制进来&#xff0c;运行了下&#xff0c;却跑不起来&…

Bootstrap系列 -- 32. 按钮垂直分组

实际运用当中&#xff0c;总会碰到垂直显示的效果。在Bootstrap框架中也提供了这样的风格。我们只需要把水平分组的“btn-group”类名换成“btn-group-vertical”即可。 <div class"btn-group-vertical"><button class"btn btn-default" type&quo…

oracle确实表达式,ORACLE正规表达式

[导读]Oracle使用正则表达式离不开这4个函数&#xff1a;Oracle使用正则表达式离不开这4个函数&#xff1a;1。regexp_like2。regexp_substr-- select regexp_substr(aaa,bb,ccccc,ddd,vvv,[^,],1,4) from dual3。regexp_instr4。regexp_replace参数1。source_char&#xff0c;…

【SpringBoot笔记】SpringBoot整合Druid数据连接池

废话少说&#xff0c;按SpringBoot的老套路来。 【step1】&#xff1a;添加依赖 <!-- 数据库连接池 --> <dependency><groupId>com.alibaba</groupId><artifactId>druid</artifactId><version>1.0.25</version> </depende…

python名字排序_python 中文排序(按拼音)

pypinyin1 排序 仅按拼音首字母 排序安装pypinyinpip3 install pypinyin代码from pypinyin import lazy_pinyinchars [鑫,鹭,榕,柘,珈,骅,孚,迦,瀚,濮,浔,沱,泸,恺,怡,岷,萃,兖]chars.sort(keylambda char: lazy_pinyin(char)[0][0])print([lazy_pinyin(char) for char in cha…

struts2中非表单标签的使用 componen

2. component标签 component标签用于使用自己的自定义组件&#xff0c;这是一个非常灵活的用法&#xff0c;如果经常需要使用某个效果片段&#xff0c;就可以考虑将这个效果片段定义成一个自定义组件&#xff0c;然后在页面中使用component标签来使用该自定义组件。因为使…

oracle 11g r2 rac中节点时间不同步,Oracle11gR2安装RAC错误之--时钟不同步

系统环境&#xff1a; 操作系统&#xff1a;RedHat EL5 Cluster&#xff1a; Oracle GI(Grid Infrastructure) Oracle&#xff1a; Oracle 11.2.0.1.0 如图所示&#xff1a;RAC 系统架系统环境&#xff1a;操作系统&#xff1a;RedHat EL5Cluster&#xff1a; Oracle GI(Grid I…

vue中pdf预览组件_Vue+ElementUI使用vue-pdf实现预览功能

Vue ElementUI项目中使用vue-pdf实现简单预览&#xff0c;供大家参考&#xff0c;具体内容如下1、安装 vue-pdfnpm install --save vue-pdf2、在vue页面中导入对应的组件我这是通过点击 预览 按钮 获取id打开一个dialog来实现:visible.sync"viewVisible" width"…

酒店预定系统

系统功能模块功能图 用例图 E-R图 转载于:https://www.cnblogs.com/qlly-20/p/9052461.html

leetcode 145. Binary Tree Postorder Traversal

传送门 145. Binary Tree Postorder Traversal QuestionEditorial SolutionMy SubmissionsTotal Accepted: 106482Total Submissions: 291244Difficulty: HardGiven a binary tree, return the postorder traversal of its nodes values. For example:Given binary tree {1,#…

74-A/D指标,Accumulation/Distribution,积累/派发线,离散指标.(2015.7.1)

A/D指标&#xff0c;Accumulation/Distribution积累/派发线&#xff0c;离散指标观井映天2015.7.1转载于:https://www.cnblogs.com/i201102053/p/10626638.html

linux 密码修改下次,问题:如何强制用户在下次登录Linux时更改密码

当你使用默认密码创建用户时&#xff0c;你必须强制用户在下一次登录时更改密码。当你在一个组织中工作时&#xff0c;此选项是强制性的。因为老员工可能知道默认密码&#xff0c;他们可能会也可能不会尝试不当行为,看到下图会不会有为用户担心的感觉&#xff1a;使用 passwd 命…

tableau获取筛选器值_认识Tableau中的筛选器

Tableau中的筛选器&#xff1a;(1)提取筛选器(2)数据源筛选器(3)上下文筛选器(4)维度筛选器(5)度量筛选器(6)参数筛选器(7)表计算筛选器(8)页面筛选器对筛选器进行简单的分类&#xff1a;数据层(提取筛选器、数据源筛选器、上下文筛选器、参数筛选器)视图层(维度筛选器、度量筛…