- 题意:P6076
- 思路:
容斥+dp
有三种下限要求方案数?我们来层层降维。
首先ans=(−1)c−i∗Cic∗f[i]
f[i]表示至多i种颜色且满足另外两限制的方案数。
很多时候我们发现,"随便","至多","至少"要好求很多,而我们要"恰好"时就会用到容斥
f[i]=(−1)m−i∗nCim−1
这里同理降维,控制列上限,行也顺便处理掉了。
- 代码:
#include<bits/stdc++.h>
using namespace std;
typedef long long ll;
const int N=405;
ll f[N],mod=1e9+7,C[N][N];
void init() {
for(int i=0;i<N;i++) C[i][0]=1;
for(int i=1;i<N;i++) {
for(int j=1;j<=i;j++) {
C[i][j]=(C[i-1][j-1]+C[i-1][j])%mod;
}
}
}
ll ksm(ll a,ll b) {
ll mul=1;
for(;b;b>>=1,a=a*a%mod) if(b&1)mul=mul*a%mod;
return mul;
}
int main() {
init();
int n,m,c;
ll opt=1;
scanf("%d%d%d",&n,&m,&c);
for(int i=1;i<=c;i++) {
opt=1;
for(int j=m;j;j--) {
f[i]+=opt*C[m][j]%mod*ksm(ksm(i+1,j)-1,n)%mod;
f[i]%=mod,opt=mod-opt;
}
}
ll ans=0; opt=1;
for(int i=c;i;i--) ans=(ans+opt*C[c][i]%mod*f[i]%mod)%mod,opt=mod-opt;
printf("%lld",ans);
return 0;
}
【推荐】国内首个AI IDE,深度理解中文开发场景,立即下载体验Trae
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· AI与.NET技术实操系列:向量存储与相似性搜索在 .NET 中的实现
· 基于Microsoft.Extensions.AI核心库实现RAG应用
· Linux系列:如何用heaptrack跟踪.NET程序的非托管内存泄露
· 开发者必知的日志记录最佳实践
· SQL Server 2025 AI相关能力初探
· 震惊!C++程序真的从main开始吗?99%的程序员都答错了
· winform 绘制太阳,地球,月球 运作规律
· 【硬核科普】Trae如何「偷看」你的代码?零基础破解AI编程运行原理
· 上周热点回顾(3.3-3.9)
· 超详细:普通电脑也行Windows部署deepseek R1训练数据并当服务器共享给他人