【题目链接】

点击打开链接

【算法】

树形DP即可

【代码】

  1. #include<bits/stdc++.h>
  2. using namespace std;
  3. #define MAXN 50
  4.  
  5. int i,j,k,n,l,r,mid;
  6. int d[MAXN],f[MAXN][MAXN],root[MAXN][MAXN];
  7.  
  8. template <typename T> inline void read(T &x) {
  9. int f = ; x = ;
  10. char c = getchar();
  11. for (; !isdigit(c); c = getchar()) { if (c == '-') f = -f; }
  12. for (; isdigit(c); c = getchar()) x = (x << ) + (x << ) + c - '';
  13. x *= f;
  14. }
  15. template <typename T> inline void write(T x) {
  16. if (x < ) { putchar('-'); x = -x; }
  17. if (x > ) write(x/);
  18. putchar(x%+'');
  19. }
  20. template <typename T> inline void writeln(T x) {
  21. write(x);
  22. puts("");
  23. }
  24. inline void dfs(int l,int r) {
  25. if (l <= r) {
  26. putchar(' ');
  27. write(root[l][r]);
  28. dfs(l,root[l][r]-);
  29. dfs(root[l][r]+,r);
  30. }
  31. }
  32.  
  33. int main() {
  34.  
  35. read(n);
  36. for (i = ; i <= n; i++) {
  37. for (j = ; j <= n; j++) {
  38. f[i][j] = ;
  39. }
  40. }
  41. for (i = ; i <= n; i++) {
  42. read(d[i]);
  43. f[i][i] = d[i];
  44. root[i][i] = i;
  45. }
  46.  
  47. for (k = ; k <= n; k++) {
  48. for (l = ; l <= n - k + ; l++) {
  49. r = l + k - ;
  50. for (mid = l; mid <= r; mid++) {
  51. if (f[l][mid-] * f[mid+][r] + d[mid] > f[l][r]) {
  52. f[l][r] = f[l][mid-] * f[mid+][r] + d[mid];
  53. root[l][r] = mid;
  54. }
  55. }
  56. }
  57. }
  58. writeln(f[][n]);
  59. write(root[][n]);
  60. dfs(,root[][n]-);
  61. dfs(root[][n]+,n);
  62.  
  63. return ;
  64.  
  65. }

【NOIP 2003】 加分二叉树的更多相关文章

  1. CODEVS1090 加分二叉树

    codevs1090 加分二叉树 2003年NOIP全国联赛提高组 题目描述 Description 设一个n个节点的二叉树tree的中序遍历为(l,2,3,…,n),其中数字1,2,3,…,n为节点 ...

  2. Vijos 1100 加分二叉树

    题目 1100 加分二叉树 2003年NOIP全国联赛提高组  时间限制: 1 s  空间限制: 128000 KB   题目描述 Description 设一个n个节点的二叉树tree的中序遍历为( ...

  3. 洛谷P1040 加分二叉树(树形dp)

    加分二叉树 时间限制: 1 Sec  内存限制: 125 MB提交: 11  解决: 7 题目描述 设一个n个节点的二叉树tree的中序遍历为(l,2,3,...,n),其中数字1,2,3,...,n ...

  4. 【算法•日更•第十期】树型动态规划&区间动态规划:加分二叉树题解

    废话不多说,直接上题: 1580:加分二叉树 时间限制: 1000 ms         内存限制: 524288 KB提交数: 121     通过数: 91 [题目描述] 原题来自:NOIP 20 ...

  5. NOIP2003加分二叉树[树 区间DP]

    题目描述 设一个n个节点的二叉树tree的中序遍历为(1,2,3,…,n),其中数字1,2,3,…,n为节点编号.每个节点都有一个分数(均为正整数),记第i个节点的分数为di,tree及它的每个子树都 ...

  6. NOIP 2003解题报告

    第一题(神经网络): 题目大意,给出一些点,每个点都有2个值,c和u,给出一些有向边,权值为w.入度为0的点的c已知,其它点的c未知,每个入度不为0的点node的c等于sum(c[k]*w[k][no ...

  7. CJOJ 1010【NOIP2003】加分二叉树 / Luogu 1040 加分二叉树(树型动态规划)

    CJOJ 1010[NOIP2003]加分二叉树 / Luogu 1040 加分二叉树(树型动态规划) Description 设 一个 n 个节点的二叉树 tree 的中序遍历为( 1,2,3,-, ...

  8. P1040 加分二叉树

    转自:(http://www.cnblogs.com/geek-007/p/7197439.html) 经典例题:加分二叉树(Luogu 1040) 设一个 n 个节点的二叉树 tree 的中序遍历为 ...

  9. 【洛谷】P1040 加分二叉树

    [洛谷]P1040 加分二叉树 题目描述 设一个n个节点的二叉树tree的中序遍历为(1,2,3,…,n),其中数字1,2,3,…,n为节点编号.每个节点都有一个分数(均为正整数),记第i个节点的分数 ...

  10. 【题解】NOI2009二叉查找树 + NOIP2003加分二叉树

    自己的思维能力果然还是太不够……想到了这棵树所有的性质即中序遍历不变,却并没有想到怎样利用这一点.在想这道题的过程中走入了诸多的误区,在这里想记录一下 & 从中吸取到的教训(原该可以避免的吧) ...

随机推荐

  1. Keil建立第一个C51工程的步骤

    参见51+arm开发板<使用手册.pdf> 1.“project”   >>  “new project”  >>  新建一个用于保存工程的文件夹例如dem  &g ...

  2. bzoj 5091: [Lydsy0711月赛]摘苹果

    5091: [Lydsy0711月赛]摘苹果 Time Limit: 1 Sec  Memory Limit: 256 MBSubmit: 148  Solved: 114[Submit][Statu ...

  3. BUPT复试专题—找K小数(2011)

    https://www.nowcoder.com/practice/204dfa6fcbc8478f993d23f693189ffd?tpId=67&tqId=29637&rp=0&a ...

  4. [转]Go基础之锁的初识

    当我们的程序就一个线程的时候是不需要用到锁的,但是通常我们实际的代码不会是单个线程的,所有这个时候就需要用到锁了,那么关于锁的使用场景主要涉及到哪些呢? 当我们多个线程在读相同的数据的时候则是需要加锁 ...

  5. kibana dev tools快捷键

    kibana dev tools快捷键 ctrl+enter  提交请求 ctrl+i 自动缩进 ctrl+enter 提交请求 down 打开自动补全菜单 enter或tab 选中项自动补全 esc ...

  6. 转: NetBean远程开发的格式与过程

    1. 介绍远程3种模式 https://netbeans.org/kb/docs/cnd/remote-modes.html 评注:英文的,3种模式讲的非常到位.服务器开发还是全远程比较不错.

  7. OCP47:155

  8. 零基础学python-5.9 集合set

    今天我们来说说set 集合:是一些唯一的.不可变的对象(数值和字符串等)的一个无序的集合(collection).而且这些对象支持与数学集合理论相相应的操作. 特点: 1.一个项仅仅可以出现一次 2. ...

  9. [java][db]JAVA分布式事务原理及应用

    JTA(Java Transaction API)同意应用程序运行分布式事务处理--在两个或多个网络计算机资源上訪问而且更新数据.JDBC驱动程序的JTA支持极大地增强了数据訪问能力.  本文的目的是 ...

  10. ViewGroup如何分发事件

    dispatchTouchEvent事件派发显示隧道方式.再是冒泡方式隧道方式传递,直道某一个元素消耗此事件,由上至下逐层分发视图.冒泡方式传递,当某个视图消耗事件后其return boolean 是 ...