题目链接:http://acm.bupt.edu.cn/onlinejudge/newoj/showProblem/show_problem.php?problem_id=1267

   
   
  1. /**算法分析:
  2.  
  3. */
  4. #include<cstdio>
  5. #include<cstring>
  6. #include<iostream>
  7. #include<algorithm>
  8. #include<vector>
  9. #include<string>
  10. #include<map>
  11. #include<set>
  12. #include<cmath>
  13. #include<sstream>
  14. #include<queue>
  15. #include<utility>
  16.  
  17. #define MAXN 505
  18. #define PI acos(-1.0)
  19. #define INF 0x3f3f3f3f
  20. #define REP(i,n) for(int i=0; i<n; i++)
  21. #define FOR(i,s,t) for(int i=s; i<=t; i++)
  22. #define show(x) { cerr<<">>>"<<#x<<" = "<<x<<endl; }
  23. #define showtwo(x,y) { cerr<<">>>"<<#x<<"="<<x<<" "<<#y<<" = "<<y<<endl; }
  24. using namespace std;
  25.  
  26. int n,q;
  27. int dp1[MAXN][MAXN]; //dp1[i][j]代表以i为根访问j个点并回到第i个点的最小路程代价
  28. int dp2[MAXN][MAXN]; //dp2[i][j]代表以i为根访问j个点不回到第i个点的最小路程代价
  29. int num[MAXN];
  30. vector<pair<int,int> > G[MAXN];
  31.  
  32. struct Store
  33. {
  34. int x,id;
  35. bool operator < (const Store& rhs) const { return x < rhs.x; }
  36. }a[MAXN*];
  37. int ans[MAXN*];
  38.  
  39. void dfs_count(int u)
  40. {
  41. num[u] = ;
  42. int sz = G[u].size();
  43. REP(i,sz)
  44. {
  45. int v = G[u][i].first;
  46. dfs_count(v);
  47. num[u] += num[v];
  48. }
  49. }
  50.  
  51. void dfs(int u,int cnt) //连根一起共访问cnt个点
  52. {
  53. if(dp2[u][cnt] != INF) return;
  54.  
  55. int sz = G[u].size();
  56. REP(i,sz)
  57. {
  58. int v = G[u][i].first;
  59. int d = G[u][i].second;
  60.  
  61. dfs(v,num[v]);
  62.  
  63. for(int k=cnt; k>=; k--) //枚举以u为根的树访问点的个数
  64. for(int j=; j<=min(num[v],k-); j++) //v这个子树要走j个点
  65. {
  66. dp1[u][k] = min(dp1[u][k],*d+dp1[v][j]+dp1[u][k-j]);
  67. dp2[u][k] = min(dp2[u][k],*d+dp1[v][j]+dp2[u][k-j]);
  68. dp2[u][k] = min(dp2[u][k],d+dp2[v][j]+dp1[u][k-j]);
  69. }
  70. }
  71. }
  72.  
  73. int main()
  74. {
  75. //freopen("E:\\acm\\input.txt","r",stdin);
  76. int test_count = ;
  77. while(cin>>n && n)
  78. {
  79. printf("Case %d:\n",test_count++);
  80. bool not_root[MAXN];
  81. memset(not_root,,sizeof(not_root));
  82. memset(dp1,0x3f,sizeof(dp1));
  83. memset(dp2,0x3f,sizeof(dp2));
  84. REP(i,n) G[i].clear();
  85. REP(i,n-)
  86. {
  87. int v,u,d;
  88. scanf("%d%d%d",&v,&u,&d);
  89. not_root[v] = true;
  90. G[u].push_back(make_pair(v,d));
  91. }
  92. int root;
  93. REP(i,n) if(!not_root[i]) root = i;
  94. REP(i,n) dp1[i][] = dp2[i][] = dp1[i][] = dp2[i][] = ;
  95.  
  96. dfs_count(root);
  97. dfs(root,n);
  98. //FOR(i,1,n) showtwo(dp2[root][i],num[i-1]);
  99.  
  100. cin>>q;
  101. REP(i,q)
  102. {
  103. scanf("%d",&a[i].x);
  104. a[i].id = i;
  105. }
  106. sort(a,a+q);
  107. int ptr = ;
  108. REP(i,q)
  109. {
  110. while(ptr<=n && dp2[root][ptr] <= a[i].x) ptr++;
  111. ans[a[i].id] = ptr-;
  112. }
  113. REP(i,q) cout<<ans[i]<<endl;
  114. }
  115. }

boj1267 Infinite’s Cave 树形dp + 背包的更多相关文章

  1. URAL_1018 Binary Apple Tree 树形DP+背包

    这个题目给定一棵树,以及树的每个树枝的苹果数量,要求在保留K个树枝的情况下最多能保留多少个苹果 一看就觉得是个树形DP,然后想出 dp[i][j]来表示第i个节点保留j个树枝的最大苹果数,但是在树形过 ...

  2. hdu1561 The more, The Better (树形dp+背包)

    题目链接:http://acm.split.hdu.edu.cn/showproblem.php?pid=1561 思路:树形dp+01背包 //看注释可以懂 用vector建树更简单. 代码: #i ...

  3. codeforces 212E IT Restaurants(树形dp+背包思想)

    题目链接:http://codeforces.com/problemset/problem/212/E 题目大意:给你一个无向树,现在用两种颜色去给这颗树上的节点染色.用(a,b)表示两种颜色分别染的 ...

  4. BZOJ.1017.[JSOI2008]魔兽地图(树形DP 背包DP)

    题目链接 树形DP,考虑子节点对父节点的贡献. 设f[x][i][j]表示当前为x,用i个x去合成上一层装备,花费为j的最大价值. 由子节点转移时 是一个分组背包,需要一个辅助数组g[i][j]表示前 ...

  5. joyOI 选课 【树形dp + 背包dp】

    题目链接 选课 题解 基础背包树形dp #include<iostream> #include<cstdio> #include<cmath> #include&l ...

  6. BZOJ1017 [JSOI2008]魔兽地图DotR 【树形dp + 背包dp】

    题目链接 BZOJ1017 题解 orz hzwer 树形dp神题 设\(f[i][j][k]\)表示\(i\)号物品恰好花费\(k\)金币,并将\(j\)个物品贡献给父亲的合成时的最大收益 计算\( ...

  7. P2015 二叉苹果树[树形dp+背包]

    题目描述 有一棵苹果树,如果树枝有分叉,一定是分2叉(就是说没有只有1个儿子的结点) 这棵树共有N个结点(叶子点或者树枝分叉点),编号为1-N,树根编号一定是1. 我们用一根树枝两端连接的结点的编号来 ...

  8. 【BZOJ-1017】魔兽地图DotR 树形DP + 背包

    1017: [JSOI2008]魔兽地图DotR Time Limit: 30 Sec  Memory Limit: 162 MBSubmit: 1566  Solved: 705[Submit][S ...

  9. hdu 1011 树形dp+背包

    题意:有n个房间结构可看成一棵树,有m个士兵,从1号房间开始让士兵向相邻的房间出发,每个房间有一定的敌人,每个士兵可以对抗20个敌人,士兵在某个房间对抗敌人使无法走开,同时有一个价值,问你花费这m个士 ...

随机推荐

  1. C# 格式化字符串(转载)

    1 前言 如果你熟悉Microsoft Foundation Classes(MFC)的CString,Windows Template Library(WTL)的CString或者Standard ...

  2. C和BlockCode

    在使用code block的时候,需要先build,然后再run,否则run的还是上次编译的内容.

  3. 使用WampServer 3.0

    在server上安装了WampServer 发现本地使用良好,但是无法从别的PC访问. 原因有二: 1.现象:输入连接无反应 原因:server本身用了80端口,所有WampServer我就设置了80 ...

  4. Java装饰设计模式的例子

    这里给出一个顾客购买咖啡的例子.其中咖啡可以加冰(2元),加巧克力(4元). 下面是面向对象中装饰模式的解决方案. /** * Created with IntelliJ IDEA. * User: ...

  5. Java中对List集合排序的两种方法

    第一种方法,就是list中对象实现Comparable接口,代码如下: public class Person implements Comparable<Person> { privat ...

  6. 关于 ASP.NET MVC 4 如果管理用户

    很久没上来写博客,因为自己没写博客的日子里去学了一下OBJECTIVE-C 和 ASP.NET MVC.最近在学ASP.NET MVC 4,有个问题一直在困扰着我,就是怎样管理用SIMPLE MEMB ...

  7. SPRING IN ACTION 第4版笔记-第七章Advanced Spring MVC-001- DispatcherServlet的高级配置(ServletRegistration.Dynamic、WebApplicationInitializer)

    一. 1.如想在DispatcherServlet在Servlet容器中注册后自定义一些操作,如开启文件上传功能,则可重写通过AbstractAnnotationConfigDispatcherSer ...

  8. 雷军的B面:那些赔到血本无归的失败投资案例

    文/李红双 雷军投资方向偏多元化布局,从电商到房地产,从互联网社区到移动互联网,多方跨界的结果必然是有失有得.本文扒一扒“雷军系”中最惨烈的电商投资,凡客诚品融资5.3亿美元目前处于垮台边缘,乐淘融资 ...

  9. socket编程在windows和linux下的区别

    如无其它说明,本文所指Linux均表示2.6内核Linux,GCC编译器,Windows均表示Windows XP系统,Visual Studio 2005 sp1编译环境. 下面大概分几个方面进行罗 ...

  10. linux下跨服务器文件文件夹的复制

    文件的复制:scp –P (端口号) ./authorized_keys berchina@hadoop002:/home/berchina 文件夹的复制:scp -r -P (端口号) /home/ ...