bzoj2111 Perm 排列计数

时间:2022-09-24 21:58:53

称一个1,2,...,N的排列P1,P2...,Pn是Magic的,当且仅当2<=i<=N时,Pi>Pi/2. 计算1,2,...N的排列中有多少是Magic的,答案可能很大,只能输出模P以后的值

Input

输入文件的第一行包含两个整数 n和p,含义如上所述。

Output

输出文件中仅包含一个整数,表示计算1,2,⋯, �的排列中, Magic排列的个数模 p的值。

Sample Input

20 23

Sample Output

16

Hint

100%的数据中,1 ≤ � N ≤ 106, P� ≤ 10^9,p是一个质数。 数据有所加强

题解:题目意思比较好理解,就是问你有多少种小根堆,那么根可以确定,然后左边右边就是

组合一下,确定,如果只有一个点,那么方案数就为1,size为1,不然就是左右子树合并。

这样瞎搞。。。(⊙o⊙)…,就好了。

 #include<iostream>
#include<cstdio>
#include<cstring>
#include<cmath>
#include<algorithm>
#define N 1000007
#define M 1007
#define ll long long
using namespace std; int n,p;
ll fac[N],ni[N],f[N];
int siz[N]; ll C(int n,int m)
{
if(m>n) return ;
if(n<p) return fac[n]*ni[m]%p*ni[n-m]%p;
return C(n/p,m/p)*C(n%p,m%p)%p;
}
int main()
{
int i;
scanf("%d%d",&n,&p);
fac[]=ni[]=ni[]=; for(i=;i<=n&&i<p;i++)
fac[i]=fac[i-]*i%p;
for(i=;i<=n&&i<p;i++)
ni[i]=(p-p/i)*ni[p%i]%p; for(i=;i<=n&&i<p;i++)
(ni[i]*=ni[i-])%=p;
for(i=n;i>=;i--)
{
if(i*+<=n)
{
siz[i]=+siz[i*]+siz[i*+];
f[i]=f[i*]*f[i*+]%p*C(siz[i]-,siz[i*])%p;
}
else if(i*<=n)
{
f[i]=f[i*];
siz[i]=+siz[i*];
}
else
{
f[i]=;
siz[i]=;
}
}
printf("%lld\n",f[]);
}

bzoj2111 Perm 排列计数的更多相关文章

  1. 【BZOJ2111】&lbrack;ZJOI2010&rsqb;Perm 排列计数 组合数

    [BZOJ2111][ZJOI2010]Perm 排列计数 Description 称一个1,2,...,N的排列P1,P2...,Pn是Magic的,当且仅当2<=i<=N时,Pi&gt ...

  2. BZOJ 2111&colon; &lbrack;ZJOI2010&rsqb;Perm 排列计数 &lbrack;Lucas定理&rsqb;

    2111: [ZJOI2010]Perm 排列计数 Time Limit: 10 Sec  Memory Limit: 259 MBSubmit: 1936  Solved: 477[Submit][ ...

  3. 2111&colon; &lbrack;ZJOI2010&rsqb;Perm 排列计数

    2111: [ZJOI2010]Perm 排列计数 链接 题意: 称一个1,2,...,N的排列$P_1,P_2...,P_n$是Magic的,当且仅当$2<=i<=N$时,$P_i&gt ...

  4. bzoj 2111&colon; &lbrack;ZJOI2010&rsqb;Perm 排列计数 (dp&plus;卢卡斯定理)

    bzoj 2111: [ZJOI2010]Perm 排列计数 1 ≤ N ≤ 10^6, P≤ 10^9 题意:求1~N的排列有多少种小根堆 1: #include<cstdio> 2: ...

  5. Perm排列计数(新博客试水,写的不好,各路大神见谅)

    B. Perm 排列计数 内存限制:512 MiB 时间限制:1000 ms 标准输入输出   题目描述 称一个1,2,...,N的排列P1,P2...,Pn是Magic的,当且仅当2<=i&l ...

  6. BZOJ2111&colon; &lbrack;ZJOI2010&rsqb;Perm 排列计数

    题目:http://www.lydsy.com/JudgeOnline/problem.php?id=2111 题意:一个1,2,...,N的排列P1,P2...,Pn是Magic的,当且仅当2&lt ...

  7. &lbrack;BZOJ2111&rsqb;&lbrack;ZJOI2010&rsqb;Perm排列计数&lpar;组合数学&rpar;

    题意就是求一个n个点的堆的合法形态数. 显然,给定堆中所有数的集合,则这个堆的根是确定的,而由于堆是完全二叉树,所以每个点左右子树的大小也是确定的. 设以i为根的堆的形态数为F(i),所以F(i)+= ...

  8. &lbrack;bzoj2111&rsqb;&lbrack;ZJOI2010&rsqb;Perm 排列计数 ——问题转换,建立数学模型

    题目大意 称一个1,2,...,N的排列P1,P2...,Pn是Magic的,当且仅当2<=i<=N时,Pi>Pi/2. 计算1,2,...N的排列中有多少是Magic的,答案可能很 ...

  9. 【bzoj2111】&lbrack;ZJOI2010&rsqb;Perm 排列计数 dp&plus;Lucas定理

    题目描述 称一个1,2,...,N的排列P1,P2...,Pn是Mogic的,当且仅当2<=i<=N时,Pi>Pi/2. 计算1,2,...N的排列中有多少是Mogic的,答案可能很 ...

随机推荐

  1. Logstash5&period;0&period;X离线安装插件报错,仍然提示无法联网

    本人最初将此解决方案发布在 ELK中文社区 http://elasticsearch.cn/question/1046 由于生产环境无法连接互联网,所有再一台联网机器上将所有插件做了 pack 拖到生 ...

  2. fatal error C1010&colon; 在查找预编译头时遇到意外的文件结尾。是否忘记了向源中添加&OpenCurlyDoubleQuote;&num;include &quot&semi;StdAfx&period;h&quot&semi;”&quest; 解决方法

    错误描述: fatal error C1010: 在查找预编译头时遇到意外的文件结尾.是否忘记了向源中添加“#include "StdAfx.h"”? 错误分析:     此错误发 ...

  3. 20145225 实验四《Andoid开发基础》

    实验内容 搭建Android环境 运行Android 修改代码,能输出学号 实验步骤 安装Android Studio 安装Android的SDK 运行Andriod Studio并在模拟手机上显示自 ...

  4. &lbrack;mysql使用&lpar;1&rpar;&rsqb; 64位Linux下安装mysql-5&period;7&period;13-linux-glibc2&period;5-x86&lowbar;64

    由于公司临时让将Oracle的数据移植到mysql上面,所以让我在公司服务器上面安装一下mysql.下面就是我的安装过程以及一些错误解决思路.其实对于不同版本安装大体都有差不多. 1. 从官网下载 m ...

  5. Django---第三方

    第三方: 3.富文本编辑器:此处以tinymce为例 使用编辑器的显示效果为: 1.下载安装 在网站pypi网站搜索并下载"django-tinymce-2.4.0" 解压 tar ...

  6. jmeter学习记录--04--Beanshell

    一.什么是Bean Shell BeanShell是一种完全符合Java语法规范的脚本语言,并且又拥有自己的一些语法和方法;BeanShell是一种松散类型的脚本语言(这点和JS类似); BeanSh ...

  7. JavaScript大杂烩16 - 推荐实践

    JavaScript部分 1. 总是使用===来进行相等判断 原因:由于 == 和 != 操作符存在类型转换问题,而为了保持代码中数据类型的完整性,推荐使用全等 === 和不全等 !=== 操作符. ...

  8. 阿里云搭建JAVA WEB环境&lpar;SQL Server &plus; TomCat &plus; 配置域名&rpar;

    假期刚刚搭完,先写个提纲,今晚写完: 1.申请一个月的免费的云服务器ECS; 2.在云服务器上安装Java开发环境+Sql Server+Tomcat; 3.购买域名并认证,绑定服务器共有IP地址; ...

  9. &lbrack;转帖&rsqb; &OpenCurlyDoubleQuote;王者对战”之 MySQL 8 vs PostgreSQL 10

    原贴地址:https://www.oschina.net/translate/showdown-mysql-8-vs-postgresql-10?lang=chs&page=2# 英文原版地址 ...

  10. 命令行启用IIS Express

    我们在调试WEB程序的时候可以把本地web程序挂载到本地IIS,然后访问程序,通过附加进程的方式(w3wp)来调试程序(个人非常喜欢的一种调试方式),还有一种比较传统的方式就是通过VS自带的F5来执行 ...