[loj2473]秘密袭击
1 #include<bits/stdc++.h>
2 using namespace std;
3 #define N 2005
4 #define mod 64123
5 #define mid (l+r>>1)
6 struct ji{
7 int nex,to;
8 }edge[N<<1];
9 struct tag{
10 int a,b,c,d;
11 }f[N*15];
12 int V,E,n,m,w,v,x,y,ans,head[N],r[N],a[N],b[N],sum[N],ch[N*15][2];
13 void add(int x,int y){
14 edge[E].nex=head[x];
15 edge[E].to=y;
16 head[x]=E++;
17 }
18 int ksm(int n,int m){
19 if (!m)return 1;
20 int s=ksm(n,m>>1);
21 s=1LL*s*s%mod;
22 if (m&1)s=1LL*s*n%mod;
23 return s;
24 }
25 int New(){
26 f[++V]=tag{1,0,0,0};
27 ch[V][0]=ch[V][1]=0;
28 return V;
29 }
30 void upd(int &k,tag x){
31 if (!k)k=New();
32 f[k].c=(1LL*f[k].a*x.c+f[k].c)%mod;
33 f[k].d=(1LL*f[k].b*x.c+f[k].d+x.d)%mod;
34 f[k].a=1LL*f[k].a*x.a%mod;
35 f[k].b=(1LL*f[k].b*x.a+x.b)%mod;
36 }
37 void down(int k){
38 upd(ch[k][0],f[k]);
39 upd(ch[k][1],f[k]);
40 f[k]=tag{1,0,0,0};
41 }
42 void update(int &k,int l,int r,int x,int y,tag z){
43 if ((l>y)||(x>r))return;
44 if (!k)k=New();
45 if ((x<=l)&&(r<=y)){
46 upd(k,z);
47 return;
48 }
49 down(k);
50 update(ch[k][0],l,mid,x,y,z);
51 update(ch[k][1],mid+1,r,x,y,z);
52 }
53 int merge(int k1,int k2){
54 if ((!k1)||(!k2))return k1+k2;
55 if ((!ch[k1][0])&&(!ch[k1][1]))swap(k1,k2);
56 if ((!ch[k2][0])&&(!ch[k2][1])){
57 f[k1].a=1LL*f[k1].a*f[k2].b%mod;
58 f[k1].b=1LL*f[k1].b*f[k2].b%mod;
59 f[k1].d=(f[k1].d+f[k2].d)%mod;
60 return k1;
61 }
62 down(k1);
63 down(k2);
64 ch[k1][0]=merge(ch[k1][0],ch[k2][0]);
65 ch[k1][1]=merge(ch[k1][1],ch[k2][1]);
66 return k1;
67 }
68 void dfs(int k,int fa){
69 upd(r[k],tag{0,1,0,0});
70 for(int i=head[k];i!=-1;i=edge[i].nex)
71 if (edge[i].to!=fa){
72 dfs(edge[i].to,k);
73 r[k]=merge(r[k],r[edge[i].to]);
74 }
75 update(r[k],1,w,1,a[k],tag{v,0,0,0});
76 upd(r[k],tag{1,0,1,0});
77 upd(r[k],tag{1,1,0,0});
78 }
79 void tot(int k,int l,int r){
80 if (l==r){
81 sum[v]=(sum[v]+f[k].d)%mod;
82 return;
83 }
84 down(k);
85 tot(ch[k][0],l,mid);
86 tot(ch[k][1],mid+1,r);
87 }
88 int main(){
89 scanf("%d%d%d",&n,&m,&w);
90 memset(head,-1,sizeof(head));
91 for(int i=1;i<=n;i++)scanf("%d",&a[i]);
92 for(int i=1;i<n;i++){
93 scanf("%d%d",&x,&y);
94 add(x,y);
95 add(y,x);
96 }
97 for(v=0;v<=n;v++){
98 V=0;
99 memset(r,0,sizeof(r));
100 dfs(1,0);
101 tot(r[1],1,w);
102 }
103 memset(a,0,sizeof(a));
104 a[0]=1;
105 for(int i=0;i<=n;i++)
106 for(int j=i+1;j>=0;j--)a[j]=(a[j-1]-i*a[j]%mod+mod)%mod;
107 for(int i=0;i<=n;i++){
108 x=1;
109 for(int j=0;j<=n;j++)
110 if (i!=j)x=1LL*x*(i-j+mod)%mod;
111 x=1LL*ksm(x,mod-2)*sum[i]%mod;
112 memcpy(b,a,sizeof(b));
113 for(int j=n+1;j;j--){
114 b[j-1]=(b[j-1]+i*b[j])%mod;
115 if (m<j)ans=(ans+1LL*b[j]*x)%mod;
116 }
117 }
118 printf("%d",ans);
119 }
[loj2473]秘密袭击的更多相关文章
- [九省联考2018]秘密袭击coat
[九省联考2018]秘密袭击coat 研究半天题解啊... 全网几乎唯一的官方做法的题解:链接 别的都是暴力.... 要是n=3333暴力就完了. 一.问题转化 每个联通块第k大的数,直观统计的话,会 ...
- 【BZOJ5250】[九省联考2018]秘密袭击(动态规划)
[BZOJ5250][九省联考2018]秘密袭击(动态规划) 题面 BZOJ 洛谷 给定一棵树,求其所有联通块的权值第\(k\)大的和. 题解 整个\(O(nk(n-k))\)的暴力剪剪枝就给过了.. ...
- LOJ #2473. 「九省联考 2018」秘密袭击
#2473. 「九省联考 2018」秘密袭击 链接 分析: 首先枚举一个权值W,计算这个多少个连通块中,第k大的数是这个权值. $f[i][j]$表示到第i个节点,有j个大于W数的连通块的个数.然后背 ...
- P4365 [九省联考2018]秘密袭击coat
$ \color{#0066ff}{ 题目描述 }$ Access Globe 最近正在玩一款战略游戏.在游戏中,他操控的角色是一名C 国士 兵.他的任务就是服从指挥官的指令参加战斗,并在战斗中取胜. ...
- [BZOJ5250][九省联考2018]秘密袭击(DP)
5250: [2018多省省队联测]秘密袭击 Time Limit: 1 Sec Memory Limit: 128 MBSubmit: 3 Solved: 0[Submit][Status][D ...
- [luogu]P4365[九省联考]秘密袭击coat(非官方正解)
题目背景 警告:滥用本题评测者将被封号 We could have had it all. . . . . . 我们本该,拥有一切 Counting on a tree. . . . . . 何至于此 ...
- 并不对劲的复健训练-bzoj5250:loj2473:p4365:[九省联考2018]秘密袭击
题目大意 有一棵\(n\)(\(n\leq 1666\))个点的树,有点权\(d_i\),点权最大值为\(w\)(\(w\leq 1666\)).给出\(k\)(\(k\leq n\)),定义一个选择 ...
- bzoj5250 [2018多省省队联测]秘密袭击
博主蒟蒻,目前还不会动态dp,所以下面说的是一个并不优秀的暴力,我会补的! 我们考虑按权值从大到小依次点亮每个点,相同权值可以同时点亮,每次点亮后,我们进行一次树形背包. 处理出$f[i][j]$表示 ...
- luogu4365 秘密袭击 (生成函数+线段树合并+拉格朗日插值)
求所有可能联通块的第k大值的和,考虑枚举这个值: $ans=\sum\limits_{i=1}^{W}{i\sum\limits_{S}{[i是第K大]}}$ 设cnt[i]为连通块中值>=i的 ...
随机推荐
- 从零入门 Serverless | Serverless Kubernetes 应用部署及扩缩容
作者 | 邓青琳(轻零) 阿里云技术专家 导读:本文分为三个部分,首先给大家演示 Serverless Kubernetes 集群的创建和业务应用的部署,其次介绍 Serverless Kuberne ...
- Java秘诀!Java关系运算符介绍
运算符丰富是 Java 语言的主要特点之一,它提供的运算符数量之多,在高级语言中是少见的. Java 语言中的运算符除了具有优先级之外,还有结合性的特点.当一个表达式中出现多种运算符时,执行的先后顺序 ...
- Python3 网络通信 网络聊天室 文件传输
Python3 网络通信 网络聊天室 文件传输 功能描述 该项目将实现一个文字和文件传输的客户端和服务器程序通信应用程序.它将传输和接收视频文件. 文本消息必须通过TCP与服务器通信,而客户端自己用U ...
- 海信A6/A6L A7Pro/CC A5PRO/A5PRO CC 安装gms google service指南
用过海信双面屏或者eink手机的朋友都知道,海信手机就是死活安装不了谷歌全家桶,因为海信的领导说跟谷歌有协议不能安装谷歌框架(还说后期google审核坚决不给安装,人家其他ov mui都可以安装).不 ...
- JavaScript常用的Hook脚本
JavaScript常用的Hook脚本 本文Hook脚本 来自 包子 页面最早加载代码Hook时机 在source里 用dom事件断点的script断点 然后刷新网页,就会断在第一个js标签,这时候就 ...
- k8s学习笔记(3)- kubectl高可用部署,扩容,升级,回滚springboot应用
前言:上一篇通过rancher管理k8s,部署服务应用扩容,高可用,本篇介绍kubectl命令行部署高可用集群节点,测试升级.扩容等 1.测试环境:3节点k3s,使用其中2节点(ubuntunode1 ...
- 从零到熟悉,带你掌握Python len() 函数的使用
摘要:本文为你带来如何找到长度内置数据类型的使用len() 使用len()与第三方数据类型 提供用于支持len()与用户定义的类. 本文分享自华为云社区<在 Python 中使用 len() 函 ...
- [技术博客]Django框架-后端的搭建
目录 Django框架-后端的搭建 前言 环境的部署 项目的创建 app的使用 创建app 修改配置文件 app中数据表的构建 前端接口 接口的路径 运行服务器 验证后端 Django框架-后端的搭建 ...
- Linux线程互斥学习笔记--详细分析
一.互斥锁 为啥要有互斥? 多个进程/线程执行的先后顺序不确定,何时切出CPU也不确定. 多个进程/线程访问变量的动作往往不是原子的. 1. 操作步骤 (1)创建锁 // 创建互斥锁mutex pth ...
- 局域网(以太网与IEEE 802.3、IEEE 802.11、)
文章转自:https://blog.csdn.net/weixin_43914604/article/details/105016637 学习课程:<2019王道考研计算机网络> 学习目的 ...