BZOJ4766: 文艺计算姬

Time Limit: 1 Sec  Memory Limit: 128 MB
Submit: 737  Solved: 402
[Submit][Status][Discuss]

Description

"奋战三星期,造台计算机"。小W响应号召,花了三星期造了台文艺计算姬。文艺计算姬比普通计算机有更多的艺

术细胞。普通计算机能计算一个带标号完全图的生成树个数,而文艺计算姬能计算一个带标号完全二分图的生成树

个数。更具体地,给定一个一边点数为n,另一边点数为m,共有n*m条边的带标号完全二分图K_{n,m},计算姬能快

速算出其生成树个数。小W不知道计算姬算的对不对,你能帮助他吗?

Input

仅一行三个整数n,m,p,表示给出的完全二分图K_{n,m}

1 <= n,m,p <= 10^18

Output

仅一行一个整数,表示完全二分图K_{n,m}的生成树个数,答案需要模p。

Sample Input

2 3 7

Sample Output

5

HINT

Source

算法1

结合MatrixTree定理打表或者归纳证明

算法2

根据prufe

r因为prufer序列对应着唯一的一棵树,问题转为计算有多少合法的prufer序列。 
“一种生成Prufer序列的方法是迭代删点,直到原图仅剩两个点。”根据prufer序列的性质,最后剩下的两个点一定有一条边,在二分图中有连边的两点一定处于不同集合。在删除时会“移去所有叶子节点(度为1的顶点)中标号最小的顶点和相连的边,并把与它相邻的点的编号加入Prufer序列中”,每删除一个点都需要将与它连边的点加到prufer序列中,而二分图中的边两端的点一定属于不同集合,那么A集合有n-1个点被删除,也就是说B集合中的数需要被加入n-1次,共有$m^n−1$种可能;B集合同理,有m-1个点被删除,也就是说A集合中的数需要被加入m-1次,共有$n^m−1$种可能。 
两种情况相乘得到答案为$n^{m−1}∗m^{n−1}$

#include<cstdio>
#include<cstring>
#include<algorithm>
#define int long long
using namespace std;
const int MAXN=1e6+10,INF=1e4+10;
inline int read()
{
    char c=getchar();int x=0,f=1;
    while(c<‘0‘||c>‘9‘){if(c==‘-‘)f=-1;c=getchar();}
    while(c>=‘0‘&&c<=‘9‘){x=x*10+c-‘0‘;c=getchar();}
    return x*f;
}
int fastmul(int a,int p,int mod)
{
    int base=0;
    while(p)
    {
        if(p&1) base=(base+a)%mod;
        a=(a+a)%mod;
        p>>=1;
    }
    return base;
}
int fastpow(int a,int p,int mod)
{
    int base=1;
    while(p)
    {
        if(p&1) base=fastmul(base,a,mod)%mod;
        a=fastmul(a,a,mod)%mod;
        p>>=1;
    }
    return base;
}
main()
{
    int N=read(),M=read(),P=read();
    printf("%lld",fastmul(fastpow(N,M-1,P),fastpow(M,N-1,P),P)%P);
     return 0;
}

原文地址:https://www.cnblogs.com/zwfymqz/p/8456205.html

时间: 2024-10-10 13:37:45

BZOJ4766: 文艺计算姬的相关文章

bzoj 4766: 文艺计算姬 -- 快速乘

4766: 文艺计算姬 Time Limit: 1 Sec  Memory Limit: 128 MB Description "奋战三星期,造台计算机".小W响应号召,花了三星期造了台文艺计算姬.文艺计算姬比普通计算机有更多的艺 术细胞.普通计算机能计算一个带标号完全图的生成树个数,而文艺计算姬能计算一个带标号完全二分图的生成树 个数.更具体地,给定一个一边点数为n,另一边点数为m,共有n*m条边的带标号完全二分图K_{n,m},计算姬能快 速算出其生成树个数.小W不知道计算姬算的对

[BZOJ4765]普通计算姬

试题描述 "奋战三星期,造台计算机".小G响应号召,花了三小时造了台普通计算姬.普通计算姬比普通计算机要厉害一些.普通计算机能计算数列区间和,而普通计算姬能计算树中子树和.更具体地,小G的计算姬可以解决这么个问题:给定一棵n个节点的带权树,节点编号为1到n,以root为根,设sum[p]表示以点p为根的这棵子树中所有节点的权值和.计算姬支持下列两种操作: 1 给定两个整数u,v,修改点u的权值为v. 2 给定两个整数l,r,计算sum[l]+sum[l+1]+....+sum[r-1]

【Foreign】无聊的计算姬 [Lucas][BSGS]

无聊的计算姬 Time Limit: 10 Sec  Memory Limit: 256 MB Description Input Output Sample Input 6 2 2 3 4 3 2 7 9 2 1 2 9 3 1 6 7 1 5 3 7 1 9 2 8 Sample Output Math Error 3 Math Error 6 6 1 HINT Source 我们可以分步骗分.(Task1直接快速幂即可.) 对于前50分: 对于Task2,我们直接暴力枚举,出现一个重复的停

【bzoj4765】 普通计算姬

题意 给出一棵有根树,$n$个点每个都有一个点权.$m$组操作每次可以修改一个点权或者询问编号在区间$[l,r]$的点的子树权值和的和. Solution 我们对节点编号分块,每一块统计该块中的节点的子树权值和的和.dfs处理出修改一个节点,需要对应修改它的祖先和它的所在的哪些块.另外再开一个树状数组,树状数组中每一个元素是对应dfs的点的权值,这样我们可以求出任意子树的权值和. 对于询问,在中间的块直接统计.两侧零散的块在树状数组上暴力查询子树权值和.所以令块的大小$S=\sqrt{n/\lo

【bzoj4765】普通计算姬(双重分块)

题目传送门:http://www.lydsy.com/JudgeOnline/problem.php?id=4765 这道题已经攒了半年多了...因为懒,一直没去写...所以今天才把这道题写出来... 如果是要维护区间权值和.子树权值和,都可以用线段树/树状数组轻松解决.但是这道题要维护的是子树权值和的区间和,这就比较难搞了. 当需要维护一些看起来很难直接维护的信息时,我们一般会想到分块.于是考虑这样的分块:按编号把每√n个节点划分为一块,维护每一块所有节点的sum值的和,然后再维护每个节点的s

[BZOJ]2017省队十连测推广赛1

听学长说有比赛就随便打一打. A.普通计算姬 题目大意:给出一棵带权树,支持一下两种操作:1.修改一个点的权值:2.给出l,r,询问以点l为根的子树和.点l+1为根的子树和.点l+2为根的子树和--点r为根的子树和的总和.(点数.操作数不超过10^5) 思路:感觉是三题中最难的.给出的[l,r]区间在树上没有实际意义,不好利用数据结构维护.考虑若不修改,可以一遍dfs算出每个点对应的dfs序,这样每棵子树都对应一个dfs序的区间,前缀和一下就能O(1)查子树和,再按点的编号顺序把子树和前缀和一下

bzoj省选十连测推广赛

A.普通计算姬 题意:给丁一棵树,每个点有一个权值,用sum(x)表示以x为根的子树的权值和,要求支持两种操作: 1 u v  :修改点u的权值为v. 2 l  r   :  求∑sum[i] l<=i<=r n,m(操作数)<=10^5 题解:数据范围比较小,考虑分块重建的做法. 求出每个点的dfs序和子树的区间,这样就可以On建出所有节点的sum的前缀和. 然后每次修改操作都把操作存下来,每次查询先找出这段区间的和,再去操作里处理这些操作对这个查询的影响. 具体实现就是:把每个点的子

行列式 矩阵 重难点

把行列式与矩阵的基础给拾起来. 未完待续. 1. 行列式的递归定义与逆序对定义是等价的. 2. 行列式的性质 3. 三角行列式, 行列式求值, 高斯消元法 4. 奇阶反对称行列式 5. 例6. 6. 范徳蒙行列式 习题30. 习题44. 7. 一个分块技巧 文艺计算姬. 8. 递推思想 轮状病毒. 习题42. 习题39. 习题43. 9. 克拉默法则 10. 三角形面积 11. 习题28. 12. 矩阵乘法的性质 13. 坐标变换 旋转 14. 矩阵乘积的行列式 15. 伴随矩阵 16. 逆矩阵

[HAOI2018] 反色游戏

做法超好想,细节调一辈子. 估计这句话最适合这个题了hhhh. 首先一个很显然的想法:把边设成未知数,对点列异或方程,最后的解的个数就是 2^自由元 . 不过如果某个联通分量里有奇数个黑点,那么问题无解.然后我来证明一下: 把一个联通分量里所有点代表的方程都异或起来,因为这个联通分量里的边恰好在其两个端点的行是1,所以最后异或出来的方程前m列都是0,如果有奇数个黑点的话,最后一列就是1,那么无解(不能0=1吧hhh). 直接高斯消元是 O(N^3) 的,肯定要gg了啊 (不过竟然给了60分消元h