题目链接

洛谷.

LOJ,LOJ机子是真的快

Solution

我直接上暴力了...\(O(n^2k)\)洛谷要\(O2\)才能过...loj平均单点一秒...

直接枚举每个点为第\(k\)大的点,然后\(dp\)出方案数统计答案就好了。

\(f[i][j]\)\(dfs\)下去的时候表示考虑到\(i\),有\(j\)个大于\(i\)的点的方案数,此时没有考虑儿子。

然后回溯的时候从叶子节点把儿子的影响加回来就好了。

#include<bits/stdc++.h>
using namespace std; void read(int &x) {
x=0;int f=1;char ch=getchar();
for(;!isdigit(ch);ch=getchar()) if(ch=='-') f=-f;
for(;isdigit(ch);ch=getchar()) x=x*10+ch-'0';x*=f;
} void print(int x) {
if(x<0) putchar('-'),x=-x;
if(!x) return ;print(x/10),putchar(x%10+48);
}
void write(int x) {if(!x) putchar('0');else print(x);putchar('\n');} #define lf double
#define ll long long const int maxn = 1700+10;
const int inf = 1e9;
const lf eps = 1e-8;
const int mod = 64123; int val[maxn],f[maxn][maxn],head[maxn],tot,n,k,w,ans,rt;
struct edge{int to,nxt;}e[maxn<<1]; void Add(int u,int v) {e[++tot]=(edge){v,head[u]},head[u]=tot;}
void ins(int u,int v) {Add(u,v),Add(v,u);} int add(int x,int y) {return x+y>mod?x+y-mod:x+y;} void dfs(int x,int fa) {
if(val[x]>val[rt]||(val[x]==val[rt]&&x>rt))
for(int i=2;i<=k;i++) f[x][i]=add(f[x][i],f[fa][i-1]);
else for(int i=1;i<=k;i++) f[x][i]=add(f[x][i],f[fa][i]);
for(int i=head[x];i;i=e[i].nxt) if(e[i].to!=fa) dfs(e[i].to,x);
if(fa) for(int i=1;i<=k;i++) f[fa][i]=add(f[fa][i],f[x][i]);
} int main() {
read(n),read(k),read(w);
for(int i=1;i<=n;i++) read(val[i]);
for(int i=1,x,y;i<n;i++) read(x),read(y),ins(x,y);
for(int i=1;i<=n;i++) {
int cnt=1;rt=i;
for(int j=1;j<=n;j++) cnt+=val[j]>val[i]||(val[j]==val[i]&&j>i);
if(cnt<k) continue;
for(int j=1;j<=n;j++)
for(int t=0;t<=k;t++) f[j][t]=0;
f[i][1]=1;for(int j=head[i];j;j=e[j].nxt) dfs(e[j].to,i);
ans=add(ans,1ll*f[i][k]*val[i]%mod);
}
write(ans);
return 0;
}

最新文章

  1. 获得设备的唯一标识符UDID
  2. POJ 2398 Toy Storage(计算几何)
  3. mvc实现上传视频预览
  4. mod-mono
  5. python练习
  6. 面试 JavaWeb 部分
  7. Spring Framework------&gt;version4.3.5.RELAESE-----&gt;Reference Documentation学习心得-----&gt;Spring Framework中web相关的知识(概述)
  8. LSM树——放弃读能力换取写能力,将多次修改放在内存中形成有序树再统一写入磁盘
  9. MVC+Ef项目(4) 抽象业务逻辑层BLL层
  10. web移动开发的小细节(持续添加)
  11. leetcode 211. Add and Search Word - Data structure design Trie树
  12. awk 中 FS的用法
  13. Java中的构造方法
  14. svn没有权限报出的错
  15. C# System.IO.StreamWriter
  16. .NET Core 如何上传文件及处理大文件上传
  17. DedecmsV5.7本地上传缩略图无法自动添加水印的解决方法
  18. linux系统编程之进程(六):父进程查询子进程的退出,wait,waitpid
  19. PHP 如何获取二维数组中某个key的集合(高性能查找)
  20. Qt监控后台服务运行状态

热门文章

  1. 3D Touch初探
  2. GitLab 自动触发 Jenkins 构建
  3. PHP调用wsdl接口实例化SoapClient抛出异常
  4. POSTMan 快速上手(一图带你玩 Postman )
  5. Pycharm中查看方法的源码
  6. (Python爬虫02) 制定爬虫的学习计划了
  7. 深入理解java虚拟机学习笔记(二)
  8. python3中使用python2中cmp函数出现错误
  9. solidity合约详解
  10. 创新手机游戏《3L》开发点滴(3)——道具、物品、装备表设计 V2(最终版)