ZOJ 3556
2024-08-31 11:03:22
终于做出来了,激动。。。。
这道题隐藏得深啊,但若推导下来,就变简单了。
首先,一个集合的子集的个数为2^n=s。注意了,题目求的是有序集合组,并且每个集合是可以重复使用的,怎么办呢?这就要想到多重集合的排列问题了。
一个多重集合有k种元素,每种元素可以无限次使用,求r-排列个数。答案为 k^r个。
这样,我们使用容斥原理:
总个数为(2^n)^k个
包含一个元素的集合有序组为 C(n,1)(2^(n-1))^k
两个的为.....C(n,2)(2^(n-2))^k
。。。。
于是二项式定理+容斥原理公式化简即为(2^k-1)^n
#include <iostream>
#include <cstdio>
#include <algorithm>
#define MOD 1000000007
using namespace std;
typedef long long LL; LL quick(LL a,LL b){
a%=MOD;
LL ans=1LL;
while(b){
if(b&1)
ans=(ans*a)%MOD;
b>>=1;
a=(a*a)%MOD;
}
return ans;
} int main(){
LL n,k;
while(cin>>n>>k){
LL r=quick(2,k);
r=((r-1)%MOD+MOD)%MOD;
r=quick(r,n);
printf("%lld\n",r);
}
return 0;
}
最新文章
- LINQ系列:LINQ to SQL Select查询
- myeclipse连接oracle步骤
- sqlserverJDBC驱动链接
- Centos添加新硬盘、分区、格式化、自动挂载
- C#调用Java类
- show engine innodb status解读
- awk的使用备忘
- Linux 安装Nginx详细图解教程
- 常用上网增强类Chrome扩展(转)
- Python基础-类的探讨(class)
- 面向对象的特性-为String类型的变量扩展一个replaceAll()函数
- torch.utils.data.DataLoader()中的pin_memory参数
- Go外包 Go语言外包 Golang外包商 浅谈Go的全局变量和生命周期
- 数据分析三剑客之一numpy
- linux 学习之路:mkdir命令使用
- WiFi-ESP8266入门http(3-1)网页认证上网-post请求(原教程)
- 新版的 selenium已经放弃PhantomJS改用Chorme headless
- BZOJ1178 APIO2009 会议中心 贪心、倍增
- Book118免费下载文档方法
- vim 删除