【卡特兰数】BZOJ1485: [HNOI2009]有趣的数列

时间:2023-02-24 19:45:07

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的值。

Solution

发现一些性质

①如果奇数位置的确定,偶数位置的也确定;

②记录奇数位置相邻“跳”过位置的个数(猎奇的表述=v=,1到3就是跳了1个位置),那么i位置已跳过的值<i,否则不合法。

对于性质②,我们可以联想到另外一种限制模型,也就是栈。

把奇数视为入栈,偶数视为出栈(具体的自己脑补)。

然后就是给定入栈求出栈。

也就是卡特兰数。

公式为C(2n,n)/(n+1)

Code

好久没有写分解质因数啥的了

自己打出来比较蠢的版本到1e6会T

于是去膜了一下别人的代码

这种筛法是线性的,同时可以求出每个数最小质因数

于是为后面的质因数分解带来了方便

 #include<cstdio>
#include<algorithm>
#include<cstring>
#include<cmath>
#define ll long long
using namespace std;
const int maxn=1e6+; int n,mod,cnt;
int flag[*maxn],prime[maxn],dy[*maxn],tot[maxn]; int getPri(){
for(int i=;i<=*n;i++){
if(!flag[i]){
prime[++cnt]=i;
dy[i]=cnt;
}
for(int j=;prime[j]*i<=*n&&j<=cnt;j++){
flag[prime[j]*i]=;
dy[prime[j]*i]=j;
if(i%prime[j]==) break;
}
}
} int add(int x,int k){
while(x!=){
tot[dy[x]]+=k;
x/=prime[dy[x]];
}
} int main(){
scanf("%d%d",&n,&mod);
getPri(); for(int i=n+;i<=*n;i++) add(i,);
for(int i=;i<=n;i++) add(i,-);
add(n+,-); ll ans=;
for(int i=;i<=cnt;i++){
while(tot[i]){
ans=(ans*prime[i])%mod;
tot[i]--;
}
}
printf("%lld\n",ans);
return ;
}

【卡特兰数】BZOJ1485: [HNOI2009]有趣的数列的更多相关文章

  1. bzoj1485&colon; &lbrack;HNOI2009&rsqb;有趣的数列&lpar;Catalan数&rpar;

    1485: [HNOI2009]有趣的数列 Time Limit: 10 Sec  Memory Limit: 64 MBSubmit: 2105  Solved: 1117[Submit][Stat ...

  2. &lbrack;bzoj1485&rsqb;&lbrack;HNOI2009&rsqb;有趣的数列&lowbar;卡特兰数&lowbar;组合数

    有趣的数列 bzoj-1485 HNOI-2009 题目大意:求所有1~2n的排列满足奇数项递增,偶数项递增.相邻奇数项大于偶数项的序列个数%P. 注释:$1\le n\le 10^6$,$1\le ...

  3. BZOJ1485&colon;&lbrack;HNOI2009&rsqb;有趣的数列&lpar;卡特兰数&rpar;

    Description 我们称一个长度为2n的数列是有趣的,当且仅当该数列满足以下三个条件: (1)它是从1到2n共2n个整数的一个排列{ai}: (2)所有的奇数项满足a1<a3<…&l ...

  4. BZOJ1485&colon; &lbrack;HNOI2009&rsqb;有趣的数列&lpar;卡特兰数+快速幂&rpar;

    题目链接 传送门 题面 思路 打表可以发现前六项分别为1,2,5,12,42,132,加上\(n=0\)时的1构成了卡特兰数的前几项. 看别人的题解说把每一个数扫一遍,奇数项当成入栈,偶数项当成出栈, ...

  5. BZOJ1485&colon; &lbrack;HNOI2009&rsqb;有趣的数列&lpar;Catalan数&comma;质因数分解求组合数&rpar;

    题意 挺简洁的. 我们称一个长度为2n的数列是有趣的,当且仅当该数列满足以下三个条件: (1)它是从1到2n共2n个整数的一个排列{ai}: (2)所有的奇数项满足a1<a3<…<a ...

  6. bzoj1485&colon; &lbrack;HNOI2009&rsqb;有趣的数列(Catalan数)

    一眼卡特兰数...写完才发现不对劲,样例怎么输出$0$...原来模数不一定是质数= =... 第一次见到模数不是质数的求组合数方法$(n,m\leq 10^7)$,记录一下... 先对于$1$~$n$ ...

  7. BZOJ1485&colon; &lbrack;HNOI2009&rsqb;有趣的数列

    Description 我们称一个长度为2n的数列是有趣的,当且仅当该数列满足以下三个条件: (1)它是从1到2n共2n个整数的一个排列{ai}: (2)所有的奇数项满足a1<a3<…&l ...

  8. BZOJ&lowbar;1485&lowbar;&lbrack;HNOI2009&rsqb;有趣的数列&lowbar;卡特兰数

    BZOJ_1485_[HNOI2009]有趣的数列_卡特兰数 Description 我们称一个长度为2n的数列是有趣的,当且仅当该数列满足以下三个条件: (1)它是从1到2n共2n个整数的一个排列{ ...

  9. &lbrack;HNOI2009&rsqb;有趣的数列 题解(卡特兰数)

    [HNOI2009]有趣的数列 Description 我们称一个长度为2n的数列是有趣的,当且仅当该数列满足以下三个条件: (1)它是从1到2n共2n个整数的一个排列{ai}: (2)所有的奇数项满 ...

随机推荐

  1. iptables详解

    Netfilter包含有三种表,三种表下共包含有五种链,链下面包含各种规则.即表包含若干链,链包含若干规则.  (一)三种表为:filter   nat  mangle 1.filter:处理与本机有 ...

  2. 错误信息&colon;attempt to create saveOrUpdate event with null entity

    错误信息:attempt to create saveOrUpdate event with null entity; 这个错误网上答案比较多,我也不多说了. 我遇到的问题是在前台传过来的参数是nul ...

  3. 关于mysql安全

    修改root用户密码: update mysql.user set password=password('new_passwd') where user='root'; flush privilege ...

  4. Java总结(一):封装——Encapsulation

    官方定义:一种将抽象性函式接口的实作细节部份包装.隐藏起来的方法.封装可以被认为是一个保护屏障,防止该类的代码和数 据被外部类定义的代码随机访问. 大白话定义:通过getter和setter方法访问私 ...

  5. Javascript和Java获取各种form表单信息的简单实例

    大家都知道我们在提交form的时候用了多种input表单.可是不是每一种input表单都是很简单的用Document.getElementById的方式就可以获取到的.有一些组合的form类似于che ...

  6. toolkit学习笔记

  7. MySQL导入txt文件

    "Flufy","Harold","cat","f","1993-2-4" "claws& ...

  8. 超级 Ping 监测工具——为您的网络状态保驾护航

    关于 Ping Ping 是一个网络命令,主要是用于确定本地主机是否能与另一台主机交换(发送与接收)数据.根据返回的信息,就可以推断 TCP/IP 参数是否设置得正确以及运行是否正常.正常情况下,Pi ...

  9. react 或 vue 中引用 jQuery 插件

    前言 今天与遇到一个令人抓狂的事情, 因为项目中有个交互太过于复杂而且冷门, 没有人封装类似react-swiper那种的移植过来的插件 只有现成的jQuery插件. 而时间并不宽裕,自己重写成rea ...

  10. MVC动态赋值的td选中,获取当前的td的ID或者值

    前台绑定数据: <div class="mailbox-content"> <table class="table"> <tbod ...