Codeforces 1097G
根本想不到
题意
给出一棵树,定义f(S)为用最少的边连通点集$ S$的边数
求$ \sum\limits f(S)^k$
$ n \leq 10^5 k \leq 200$
题解
假设$ k=1$有一个清真的树形$ DP$
在点集的$ LCA$处统计答案即可
对于$ k>1$根据二项式定理
可以$ O(nk^2)$完成转移
但这是过不去的
考虑
$$ x^k=\sum_{i=0}^k \binom{x}{i}S(k,i)i!$$
其中$ S(i,j)$表示第二类斯特林数
拆开组合数得
$$ x^k=\sum_{i=0}^k \frac{x!}{(x-i)!}S(k,i)$$
因此我们只要维护所有的下降幂就可以还原出$ x^k$
诶等等...这复杂度还是$ nk^2$的啊...
冷静分析一下,假设当前选取的边集大小不超过$ k$那下降幂为$ 0$
因此我们只需要枚举到$ min(当前非0下降幂的长度,k)$即可
根据树上背包的复杂度分析,其实是$ O(nk)$的
代码
#include<ctime>
#include<cmath>
#include<cstdio>
#include<cstring>
#include<iostream>
#include<algorithm>
#include<queue>
#include<vector>
#define p 1000000007
#define rt register int
#define ll long long
using namespace std;
inline ll read(){
ll x=;char zf=;char ch=getchar();
while(ch!='-'&&!isdigit(ch))ch=getchar();
if(ch=='-')zf=-,ch=getchar();
while(isdigit(ch))x=x*+ch-'',ch=getchar();return x*zf;
}
void write(ll y){if(y<)putchar('-'),y=-y;if(y>)write(y/);putchar(y%+);}
void writeln(const ll y){write(y);putchar('\n');}
int k,m,n,x,y,z,cnt;
vector<int>e[];
int S[][],f[][],mi[],sz[],ans[];
void dfs(int x,int pre){
f[x][]=sz[x]=;
for(auto v:e[x])if(v!=pre){
dfs(v,x);
for(rt i=min(sz[v]-,k-);i>=;i--){
int val=f[v][i];
if(!i)val=1ll*val*(-mi[sz[v]])%p;
(ans[i+]+=1ll*val*(-mi[n-sz[v]])%p)%=p;
(f[v][i+]+=val)%=p;
}
for(rt i=min(sz[x]-,k);i>=;i--)
for(rt j=;j<=sz[v]&&i+j<=k;j++){
const int val=1ll*f[x][i]*f[v][j]%p;
if(i)(ans[i+j]+=val)%=p;
(f[x][i+j]+=val)%=p;
}
sz[x]+=sz[v];
}
}
#define inv2 500000004
int main(){
n=read(),k=read();
S[][]=;
for(rt i=;i<=k;i++)
for(rt j=;j<=i;j++)S[i][j]=(S[i-][j-]+1ll*S[i-][j]*j%p)%p;
for(rt i=;i<n;i++){
x=read();y=read();
e[x].push_back(y);
e[y].push_back(x);
}
mi[]=;
for(rt i=;i<=n;i++)mi[i]=1ll*mi[i-]*inv2%p;
dfs(,);
int ret=,jc=;
for(rt i=;i<=k;i++)(ret+=1ll*S[k][i]*jc%p*ans[i]%p)%=p,jc=1ll*jc*(i+)%p;
for(rt i=;i<=n;i++)ret=2ll*ret%p;
cout<<(ret+p)%p;
return ;
}
Codeforces 1097G的更多相关文章
- Codeforces 1097G Vladislav and a Great Legend [树形DP,斯特林数]
洛谷 Codeforces 这题真是妙的很. 通过看题解,终于知道了\(\sum_n f(n)^k\)这种东西怎么算. update:经过思考,我对这题有了更深的理解,现将更新内容放在原题解下方. ...
- Codeforces 1097G - Vladislav and a Great Legend(第二类斯特林数+树上背包)
Codeforces 题目传送门 & 洛谷题目传送门 首先看到这题我的第一反应是:这题跟这题长得好像,不管三七二十一先把 \(k\) 次方展开成斯特林数的形式,\(f(X)^k=\sum\li ...
- CodeForces 1097G. Vladislav and a Great Legend
题目简述:给定$n \leq 10^5$个节点的树$T = (V, E)$,令$X \subseteq V$表示一个非空节点集合,定义$f(X)$为包含$X$的最小子树的边数.求 $$ \sum_{\ ...
- 学习总结:斯特林数( Stirling number )
基本定义 第一类斯特林数:$1 \dots n$的排列中恰好有$k$个环的个数:或是,$n$元置换可分解为$k$个独立的轮换的个数.记作 $$ \begin{bmatrix} n \\ k \end{ ...
- python爬虫学习(5) —— 扒一下codeforces题面
上一次我们拿学校的URP做了个小小的demo.... 其实我们还可以把每个学生的证件照爬下来做成一个证件照校花校草评比 另外也可以写一个物理实验自动选课... 但是出于多种原因,,还是绕开这些敏感话题 ...
- 【Codeforces 738D】Sea Battle(贪心)
http://codeforces.com/contest/738/problem/D Galya is playing one-dimensional Sea Battle on a 1 × n g ...
- 【Codeforces 738C】Road to Cinema
http://codeforces.com/contest/738/problem/C Vasya is currently at a car rental service, and he wants ...
- 【Codeforces 738A】Interview with Oleg
http://codeforces.com/contest/738/problem/A Polycarp has interviewed Oleg and has written the interv ...
- CodeForces - 662A Gambling Nim
http://codeforces.com/problemset/problem/662/A 题目大意: 给定n(n <= 500000)张卡片,每张卡片的两个面都写有数字,每个面都有0.5的概 ...
随机推荐
- 【jq】prop和attr的区别
prop()函数的结果: 1.如果有相应的属性,返回指定属性值. 2.如果没有相应的属性,返回值是空字符串. attr()函数的结果: 1.如果有相应的属性,返回指定属性值. 2.如果没有相应的属性, ...
- linux用户身份和文件权限
1.用户身份与能力 root管理员是linux 的超级用户,他拥有系统的所有权,能够管理系统的各项功能,如添加/删除用户,启动/关闭服务进程,开启/禁用硬件设备…… "Linux系统中的管理 ...
- 前端——JavaScript
何谓JavaScript?它与Java有什么关系? JavaScript与HTML.CSS组合使用应用于前端开发,JavaScript是一门独立的语言,浏览器内置了JS的解释器.它除了和Java名字长 ...
- Kali Linux Netcat 学习 与 网络攻击
Netcat 网络攻击 以及 应用 1.用Netcat进行黑客攻击第1部分:基础知识 Netcat是一个很好的网络实用程序,用于使用TCP和UPD协议读取和写入网络连接.Netcat通常被称为网络工具 ...
- Django缓存和内置信号
缓存 简单概括就是将对数据库操作查询所得到的数据放入另外一台机器上(缓存)中,当用户再次请求时,直接去缓存中拿,避免对数据库的频繁操作,加快数据的显示时间,需要知道的是,缓存里面的数据一般都设置有超时 ...
- Linux slave配置
说明:master机器为Windows,现将一台Linux机器作为slave进行配置.这台Linux机器为CentOS. 1.在Linux slave上的配置 ①创建名为jenkins用户 #sudo ...
- monkey日志管理
日志管理作用 Monkey日志管理是Monkey测试中非常重要的一个环节,通过日志管理分析,可以获取当前测试对象在测试过程中是否会发生异常,以及发生的概率,同时还可以获取对应的错误信息,帮助开发定位和 ...
- python 爬取可用
#coding:utf-8 from bs4 import BeautifulSoup import time import threading import random import telnet ...
- spring boot简单的小demo(适合于初学者)
import com.example.demo2.com.example.dao.ShopDao; import com.example.demo2.com.example.entity.Shops; ...
- vue实战记录(四)- vue实现购物车功能之过滤器的使用
vue实战,一步步实现vue购物车功能的过程记录,课程与素材来自慕课网,自己搭建了express本地服务器来请求数据 作者:狐狸家的鱼 本文链接:vue实战-实现购物车功能(四) GitHub:sue ...