P1040-加分二叉树
这道题放在深度优先搜索的训练题中,可是我实在没有看出来应该怎么搜索。看了题解以后才看出来是一个很简单的dp(我果然还是太菜了)
看出dp并且算出来最大的分数不是很复杂,关键是输出给定中序遍历序列的二叉树的先序遍历,要用一个数组保存在dp的时候确定的根节点,觉得不是很容易想到。
AC代码:

#include<cstdio>
#include<cstring>
#include<algorithm>
using namespace std;typedef long long ll;
const int MAXN=35;
int n,first=1;
int father[MAXN][MAXN];
ll score[MAXN][MAXN];ll search(int l,int r)
{ll tmp;if(l>r) return 1;    //如果l>r说明没有子树,应该为1,乘起来以后就变成了只有左子树或者右子树//不用考虑叶子节点,因为叶子节点的分数是它本身,所以不会进行dpif(score[l][r]==-1){for(int k=l;k<=r;k++){tmp=search(l,k-1)*search(k+1,r)+score[k][k];if(tmp>score[l][r]){score[l][r]=tmp;father[l][r]=k;    //保存这一段的根节点}}}return score[l][r];
}
void print(int l,int r)
{if(l>r) return;if(first)first=0;elseprintf(" ");printf("%d",father[l][r]);print(l,father[l][r]-1);print(father[l][r]+1,r);
}
int main()
{scanf("%d",&n);for(int i=1;i<=n;i++){scanf("%lld",&score[i][i]);father[i][i]=i;for(int j=i+1;j<=n;j++){score[i][j]=-1;}}printf("%lld\n",search(1,n));print(1,n);return 0;
}

洛谷P1040-加分二叉树-dp+二叉树相关推荐

  1. [洛谷P1040] 加分二叉树

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

  2. 洛谷P1040 加分二叉树运用区间DP(动态规划)求解

    首先放上原题链接 点我,点我进入原题 什么是动态规划? 在这类问题中,可能会有许多可行解.每一个解都对应于一个值,我们希望找到具有最优值的解.而且每次求出的解不是独立的,我们需要逐层推出最优解. 以这 ...

  3. 洛谷--橙色百道DP总结

    最近刷完了洛谷橙色DP大约一百道,算是发现了一些套路,就部分题目做一些总结. 大概分为三类 第一类,九大背包及其衍生 第二类,经典DP模型,如LCS,LIS等 第三类,实际问题背景的普通,环形,树上D ...

  4. 加分二叉树(洛谷-P1040)

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

  5. Educational Codeforces Round 81 (Rated for Div. 2) F.Good Contest \ 洛谷 划艇 组合 计数dp

    cf传送门 P3643 [APIO2016]划艇 文章目录 题意: 思路: 题意: aia_iai​在[li,ri][l_i,r_i][li​,ri​]等概率随机选一个数,求aaa数组不增的概率. 思 ...

  6. 洛谷P1108 低价购买[DP | LIS方案数]

    题目描述 "低价购买"这条建议是在奶牛股票市场取得成功的一半规则.要想被认为是伟大的投资者,你必须遵循以下的问题建议:"低价购买:再低价购买".每次你购买一支股 ...

  7. 洛谷P1244 青蛙过河 DP/思路

    又是一道奇奇怪怪的DP(其实是思路题). 原文戳>>https://www.luogu.org/problem/show?pid=1244<< 这题的意思给的挺模糊,需要一定的 ...

  8. 洛谷 P2657 (数位DP)

    ### 洛谷 P2657 题目链接 ### 题目大意:给你一个数的范围 [A,B] ,问你这段区间内,有几个数满足如下条件: 1.两个相邻数位上的数的差值至少为 2 . 2.不包含前导零. 很简单的数 ...

  9. 洛谷 Golden Sword(dp,优先队列优化【含板子】)|| 补充练习:洛谷 跳房子

    题目链接: 「SWTR-03」Golden Sword - 洛谷 思路: 设表示放第i个原料,锅里共有 j 个时的耐久度之和. 容易知道dp方程为,其中 这样就可以写出暴力dp的代码如下:(需要枚举i ...

最新文章

  1. python自动化框架pytest pdf_pytest+python下的UI自动化基础框架
  2. 基于kryo序列化方案的memcached-session-manager多memcached...
  3. 把我坑惨的一个update语句!
  4. 前谷歌董事长施密特:美国AI领导地位岌岌可危,科研预算投入得翻倍
  5. 视觉直观感受7种常用排序算法
  6. 如何解决div层被flash遮盖的问题
  7. 神策 2021 数据驱动大会嘉宾阵容首曝 + 精彩观点前瞻
  8. linux centos 编译luabind-0.9.1 动态库 静态库
  9. python第七天--字符串的方法与注释
  10. 这可能是 Python 面向对象编程的最佳实践
  11. 剑指offer(C++)-JZ34:二叉树中和为某一值的路径(二)(数据结构-树)
  12. 基于Ubuntu的ESP32平台搭建
  13. R语言开发软件包(打包)
  14. 稻盛和夫《活法》读书笔记
  15. android lut格式文件下载,一键调色?教你用Lut直接调出电影色调(内含下载)
  16. 一键加速去不掉加锁的_vivo手机一键加速的时候,怎样可以不把当前的应用清除?...
  17. 作为一个准研究生,怎样才能在研究生阶段不虚度?
  18. 大小端与高位先行、低位先行
  19. 你是我无法斑驳的阳光
  20. 2020牛客暑期多校训练营(第五场)题解

热门文章

  1. Mathematica图片局部变色
  2. 程序猿果真有前端后端client吗
  3. Linux下面的IO模型
  4. 49-今日交易总结.(2015.1.13)
  5. SharePoint2013安装组件时AppFabric时出现1603错误,解决方法:
  6. 简述WebService与.NET Remoting的区别及适应场合
  7. php resque 计划任务,PHP-RESQUE - 实现重试
  8. php gps 坐标,php 计算gps坐标 距离
  9. 在服务器中开虚拟机,可以在云服务器上开虚拟机
  10. java concurrent 例子_[Java Concurrent] 并发访问共享资源的简单案例