T1题面:

 输入点数为N一棵树

 求树上长度恰好为K的路径个数

 (n < 1e5, k < 500)

  这是今天的考试题,也是一道假的紫题,因为我一个根本不会dp的蒟蒻只知道状态就一遍A掉了……(然后我当时不会……emm)

  考虑f[i][j]表示点i为根的子树中深度为j的点的个数,初始设置f[i][0] = 1。转移的时候,每搞完一棵子树就用这棵子树内的数据用乘法原理更新ans,然后再把它的贡献累加给根,这样可以保证统计不重不漏。

  也可以用点分治来做。

代码:

  1. #include <iostream>
  2. #include <cstdio>
  3. #define maxn 50010
  4. using namespace std;
  5. template <typename T>
  6. void read(T &x) {
  7. x = 0;
  8. int f = 1;
  9. char ch = getchar();
  10. while (!isdigit(ch)) {
  11. if (ch == '-')
  12. f = -1;
  13. ch = getchar();
  14. }
  15. while (isdigit(ch)) {
  16. x = x * 10 + (ch ^ 48);
  17. ch = getchar();
  18. }
  19. x *= f;
  20. return;
  21. }
  22. void open_file(string s) {
  23. string In = s + ".in", Out = s + ".out";
  24. freopen(In.c_str(), "r", stdin);
  25. freopen(Out.c_str(), "w", stdout);
  26. }
  27. int head[maxn], top, n, k;
  28. struct E {
  29. int to, nxt;
  30. } edge[maxn << 1];
  31. inline void insert(int u, int v) {
  32. edge[++top] = (E) {v, head[u]};
  33. head[u] = top;
  34. }
  35. int f[maxn][510];//第二维j表示深度为j的点数
  36. long long ans;
  37. void dp(int u, int pre) {
  38. for (int i = head[u]; i; i = edge[i].nxt) {
  39. int v = edge[i].to;
  40. if (v == pre)
  41. continue;
  42. dp(v, u);
  43. for (int i = 0; i < k; ++i) //先统计答案
  44. ans += f[u][i] * f[v][k-i-1];
  45. for (int i = 1; i <= k; ++i) //算贡献
  46. f[u][i] += f[v][i-1];
  47. }
  48. return;
  49. }
  50. int main() {
  51. //  open_file("distance");
  52. read(n), read(k);
  53. int u, v;
  54. for (int i = 1; i < n; ++i) {
  55. read(u), read(v);
  56. insert(u, v), insert(v, u);
  57. }
  58. for (int i = 1; i <= n; ++i)
  59. f[i][0] = 1;
  60. dp(1, 0);
  61. printf("%I64d\n", ans);
  62. return 0;
  63. }

  T2题面就不放了。这是一道树形dp的入门题。

  考虑每个点可以有选与不选两种状态,设f[i][0]表示不选这个点后以该点为根的最大贡献,f[i][1]表示选。我们可以自底向顶转移,有f[u][1] = w[u] + sigma(f[v][0]),f[u][0] = sigma(max(f[v][0], f[v][1])。注意第二个方程中选不选子节点是都可以的,要注意这种比较松的限制可能遗漏。

代码:

  1. #include <iostream>
  2. #include <cstdio>
  3. #define maxn 6010
  4. template <typename T>
  5. void read(T &x) {
  6. x = 0;
  7. int f = 1;
  8. char ch = getchar();
  9. while (!isdigit(ch)) {
  10. if (ch == '-')
  11. f = -1;
  12. ch = getchar();
  13. }
  14. while (isdigit(ch)) {
  15. x = x * 10 + (ch ^ 48);
  16. ch = getchar();
  17. }
  18. x *= f;
  19. return;
  20. }
  21. using namespace std;
  22. int head[maxn], top;
  23. struct E {
  24. int to, nxt;
  25. } edge[maxn << 1];
  26. inline void insert(int u, int v) {
  27. edge[++top] = (E) {v, head[u]};
  28. head[u] = top;
  29. }
  30. int f[maxn][2], w[maxn], ind[maxn], n, root;
  31. void dp(int u) {
  32. f[u][1] = w[u];
  33. for (int i = head[u]; i; i = edge[i].nxt) {
  34. int v = edge[i].to;
  35. dp(v);
  36. f[u][1] += f[v][0];
  37. f[u][0] += max(f[v][1], f[v][0]);
  38. }
  39. return;
  40. }
  41. int main() {
  42. read(n);
  43. for (int i = 1; i <= n; ++i)
  44. read(w[i]);
  45. int u, v;
  46. for (int i = 1; i < n; ++i) {
  47. read(u), read(v);
  48. insert(v, u);
  49. ++ind[u];
  50. }
  51. for (int i = 1; i <= n; ++i)
  52. if (!ind[i]) {
  53. root = i;
  54. break;
  55. }
  56. dp(root);
  57. printf("%d", max(f[root][0], f[root][1]));
  58. return 0;
  59. }

【树形dp】【CF161D】distance on a tree + 【P1352】没有上司的舞会的更多相关文章

  1. (树形DP入门题)Anniversary party(没有上司的舞会) HDU - 1520

    题意: 有个公司要举行一场晚会.为了让到会的每个人不受他的直接上司约束而能玩得开心,公司领导决定:如果邀请了某个人,那么一定不会再邀请他的直接的上司,但该人的上司的上司,上司的上司的上司等都可以邀请. ...

  2. 洛谷 p1352 没有上司的舞会 题解

    P1352 没有上司的舞会 题目描述 某大学有N个职员,编号为1~N.他们之间有从属关系,也就是说他们的关系就像一棵以校长为根的树,父结点就是子结点的直接上司.现在有个周年庆宴会,宴会每邀请来一个职员 ...

  3. 洛谷P1352 没有上司的舞会——树形DP

    第一次自己写树形DP的题,发个博客纪念`- 题目来源:P1352 没有上司的舞会 题目描述 某大学有N个职员,编号为1~N.他们之间有从属关系,也就是说他们的关系就像一棵以校长为根的树,父结点就是子结 ...

  4. P1352 没有上司的舞会——树形DP入门

    P1352 没有上司的舞会 题目描述 某大学有N个职员,编号为1~N.他们之间有从属关系,也就是说他们的关系就像一棵以校长为根的树,父结点就是子结点的直接上司.现在有个周年庆宴会,宴会每邀请来一个职员 ...

  5. 洛谷P1352 没有上司的舞会 [2017年5月计划 清北学堂51精英班Day3]

    P1352 没有上司的舞会 题目描述 某大学有N个职员,编号为1~N.他们之间有从属关系,也就是说他们的关系就像一棵以校长为根的树,父结点就是子 结点的直接上司.现在有个周年庆宴会,宴会每邀请来一个职 ...

  6. luogu P1352 没有上司的舞会 x

    P1352 没有上司的舞会 题目描述 某大学有N个职员,编号为1~N.他们之间有从属关系,也就是说他们的关系就像一棵以校长为根的树,父结点就是子结点的直接上司.现在有个周年庆宴会,宴会每邀请来一个职员 ...

  7. P1352 没有上司的舞会&&树形DP入门

    https://www.luogu.com.cn/problem/P1352 题目描述 某大学有N个职员,编号为1~N.他们之间有从属关系,也就是说他们的关系就像一棵以校长为根的树,父结点就是子结点的 ...

  8. [luogu]P1352 没有上司的舞会[树形DP]

    本Lowbee第一次写树形DP啊,弱...一个变量写错半天没看出来...... 题目描述 某大学有N个职员,编号为1~N.他们之间有从属关系,也就是说他们的关系就像一棵以校长为根的树,父结点就是子结点 ...

  9. 【树形dp】Bzoj3391 [Usaco2004 Dec]Tree Cutting网络破坏

    Description     约翰意识到贝茜建设网络花费了他巨额的经费,就把她解雇了.贝茜很愤怒,打算狠狠报 复.她打算破坏刚建成的约翰的网络.    约翰的网络是树形的,连接着N(1≤N≤1000 ...

  10. 洛谷 P1352 没有上司的舞会【树形DP】(经典)

    <题目链接> <转载于>>> > 题目描述: 某大学有N个职员,编号为1~N.他们之间有从属关系,也就是说他们的关系就像一棵以校长为根的树,父结点就是子结点的 ...

随机推荐

  1. exe打包成安装文件(界面美观)

    前言 在开发windows桌面应用过程中,软件交付时,一般都是交付安装包. 安装文件的优点 显得更正规,安装界面也可展示软件特点介绍,可自动生成桌面图标等: 安装包体积要比软件小,方便下载. 探索之路 ...

  2. Eureka实现注册中心

    CAP原则又称CAP定理,指的是在一个分布式系统中,Consistency(一致性). Availability(可用性).Partition tolerance(分区容错性),三者不可得兼.它是分布 ...

  3. 当浏览器窗口大小发生变化时,重新绘制JsPlumb中的线条、端点

    1 window.addEventListener('resize', () => { 2 this.plumbInstance.repaintEverything() 3 }) 参考文章:ht ...

  4. eclipse之SSH配置hibernate【三】

    配置hibernate,没有和spring整合,可以看成独立的部分. 在src下创建hibernate配置文件,hibernate.cfg.xml.主要是sql连接相关配置. <?xml ver ...

  5. 给Swagger换一套皮肤 Knife4j集成记录

    Swagger有一套经典的UI,但是并不是很好用,之前有看到Knife4j,界面没管.功能完善,因此尝试集成. demo参考示例地址:knife4j-spring-boot-demo Knife4j前 ...

  6. 云计算之路-出海记:蹭一张 aws 船票

    出海记开篇之后,在 aws 上搭建博客园海外站的出海计划今天开始迈出第一步 -- 注册一个 aws 海外区域账号. aws 现在针对新注册用户提供12个月免费套餐(正在园子里推广并提供了专属注册通道) ...

  7. 对于RBAC与shiro的一些思考

    一.什么是RBAC模型 RBAC模型是一个解决用户权限问题的设计思维. 在最简单的RBAC模型中,将用户表设计为如下几个表 1.用户 2.角色 3.权限 以及这三张表衍生出来的两张中间表 4.用户_角 ...

  8. 辨析:IIR(Infinite Impulse Response)与FIR(Finite Impulse Response)

    IIR和FIR系统描述的是系统的抽样响应特性,其中$ x(n)=\delta(n) $ 举例:一个平均器的系统是FIR系统,因为它的抽样响应仅在变量n取某3个值的时候有值,是有限长的:一阶自回归模型由 ...

  9. VSCcode中使用git

    1.配置 文件 -> 首选项 -> 配置 出现json格式的配置项,左侧为默认设置,右侧为自定义设置: 加一行: "git.path":  Git目录下cmd下的git ...

  10. C的输入&输出

    格式说明符 输出 %d整型输出,%ld长整型输出, %o以八进制数形式输出整数, %x以十六进制数形式输出整数,或输出字符串的地址. %u以十进制数输出unsigned型数据(无符号数).注意:%d与 ...