jzoj5923
我們可以記f[i]表示i個點的連通圖的個數
則我們可以考慮將i個點不必聯通的圖個數(記為g)減去i個點的不連通圖個數
那麼f[i]=g[i]-c(j-1,i-1)f[j]gi-j
枚舉一個j,強制將j定為包含點1的聯通塊的點的個數
然後這兩個部分不能連邊
則現在的不連通圖個數為(使j個點聯通的方案(i-j)個點不必聯通的方案在2i這些點中,選出j-1個點作為i聯通塊內部的點的方案個數) 並且我們這i個點不能全聯通,所以j只能枚舉到i-1 再記f1[i]表示i個點最大聯通塊點數<=k的方案數 枚舉一個j表示現在包含1的聯通塊大小 那麼j對答案的貢獻為(使j個點聯通的方案*(i-j)個點中最大聯通塊點數<=k的方案數*在2
i這些點中,選出j-1個點作為i聯通塊內部的點的方案個數)
由於我們最大聯通塊個數不能超過k,所以j不能超過min(i,k)
那麼f1[i]=c(j-1,i-1)*f[j]*f1i-j
也是這兩部分不能連邊
最後,我們答案說最大聯通塊大小==k,所以可以拆成<=k和<k的情況,相減就是答案
這種dp方式比較套路,但是比較難想到,所以要多積累,多做這種類型的題
雖然可以使用ntt優化,但是暴力也足夠了
#include<bits/stdc++.h>
using namespace std;
typedef long long ll;
#define mo 998244353ll
ll n,k,f[2010],g[2010],jc[2010],ijc[2010],f1[2010];
ll qp(ll x,ll y){
ll r=1;
while(y){
if(y&1)r=r*x%mo;
x=x*x%mo;
y>>=1;
}
return r;
}
ll c(ll x,ll y){
return jc[y]*ijc[y-x]%mo*ijc[x]%mo;
}
ll getc(){
jc[0]=ijc[0]=1;
for(ll i=1;i<=n;i++){
jc[i]=jc[i-1]*i%mo;
ijc[i]=qp(jc[i],mo-2);
}
g[1]=1;
for(ll i=2;i<=n;i++)
g[i]=qp(2,i*(i-1)/2);
f[1]=1;
for(ll i=2;i<=n;i++){
f[i]=g[i];
for(ll j=1;j<i;j++)
f[i]=(f[i]-f[j]*g[i-j]%mo*c(j-1,i-1)%mo+mo)%mo;
}
}
ll solve(ll k){
memset(f1,0,sizeof(f1));
f1[1]=f1[0]=1;
for(ll i=2;i<=n;i++)
for(ll j=1;j<=min(i,k);j++)
f1[i]=(f1[i]+f[j]*f1[i-j]%mo*c(j-1,i-1)%mo)%mo;
return f1[n];
}
int main(){
freopen("bomb.in","r",stdin);
freopen("bomb.out","w",stdout);
scanf("%lld%lld",&n,&k);
getc();
printf("%lld\n",(solve(k)-solve(k-1)+mo)%mo);
}
jzoj5923的更多相关文章
- NOIP前的刷题记录
因为这几天要加油,懒得每篇都来写题解了,就这里记录一下加上一句话题解好了 P4071 [SDOI2016]排列计数 组合数+错排 loj 6217 扑克牌 暴力背包 P2511 [HAOI2008 ...
随机推荐
- 创建和修改主键 (SQL)
添加主键, ALTER TABLE [表名:OrderInfo] Add PRIMARY KEY ([列名:ProductID, UserID...]) 多个列则是组合主键 删除主键, ALTER ...
- SQL 将一个字段内用逗号分隔的内容分成多条记录
转自:http://www.cnblogs.com/zfanlong1314/archive/2013/01/14/2859848.html --> 测试数据 if not object_id( ...
- PAT 1044 火星数字(20)(思路+代码)
1044 火星数字(20)(20 分) 火星人是以13进制计数的: 地球人的0被火星人称为tret. 地球人数字1到12的火星文分别为:jan, feb, mar, apr, may, jun, jl ...
- [NOI.AC]COUNT(数学)
解析: 也可以将所有的可能都计算出来,后进行减法运算. 代码: #include<bits/stdc++.h> using namespace std; #define ll long l ...
- ubuntu下常用操作
屏幕截图: 可以用ubuntu自带的截图软件:gnome-screenshot. 该工具截图区域并且复制到剪切板命令为 gnome-screenshot -c -a,可以给该命令添加快捷方式,alt ...
- Java数据结构和算法(二)顺序存储的树结构
Java数据结构和算法(二)顺序存储的树结构 数据结构与算法目录(https://www.cnblogs.com/binarylei/p/10115867.html) 二叉树也可以用数组存储,可以和完 ...
- 使用RSA进行信息加密解密的WebService示例
使用RSA进行信息加密解密的WebService示例 按:以下文字涉及RSA对WebService传递的数据的加密解密,如果您已经熟知RSA或是有其它更好的方法请不要往下看以免浪费时间. WebSer ...
- cucumber安装可能发生的错误
1.--ignore-certification-errors 解决:可能是你的chromedriver版本与ruby版本不匹配,换一个版本 2.找不到文件,certification verify ...
- Devexpress VCL Build v2013 vol 13.2.4 发布
不说了,自己看吧. What's New in 13.2.4 (VCL Product Line) New Major Features in 13.2 What's New in VCL Pro ...
- 2018.10.20 bzoj1925: [Sdoi2010]地精部落(dp)
传送门 dp好题. 设f[i][j]f[i][j]f[i][j]表示iii个数结尾是jjj且结尾两个数递增的方案数. 那么显然可以对称的定义出g[i][j]g[i][j]g[i][j]表示iii个数结 ...