洛谷P1040-加分二叉树-dp+二叉树
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+二叉树相关推荐
- [洛谷P1040] 加分二叉树
洛谷题目链接:加分二叉树 题目描述 设一个n个节点的二叉树tree的中序遍历为(1,2,3,-,n),其中数字1,2,3,-,n为节点编号.每个节点都有一个分数(均为正整数),记第i个节点的分数为di ...
- 洛谷P1040 加分二叉树运用区间DP(动态规划)求解
首先放上原题链接 点我,点我进入原题 什么是动态规划? 在这类问题中,可能会有许多可行解.每一个解都对应于一个值,我们希望找到具有最优值的解.而且每次求出的解不是独立的,我们需要逐层推出最优解. 以这 ...
- 洛谷--橙色百道DP总结
最近刷完了洛谷橙色DP大约一百道,算是发现了一些套路,就部分题目做一些总结. 大概分为三类 第一类,九大背包及其衍生 第二类,经典DP模型,如LCS,LIS等 第三类,实际问题背景的普通,环形,树上D ...
- 加分二叉树(洛谷-P1040)
题目描述 设一个n个节点的二叉树tree的中序遍历为(1,2,3,-,n),其中数字1,2,3,-,n为节点编号.每个节点都有一个分数(均为正整数),记第i个节点的分数为di,tree及它的每个子树都 ...
- 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数组不增的概率. 思 ...
- 洛谷P1108 低价购买[DP | LIS方案数]
题目描述 "低价购买"这条建议是在奶牛股票市场取得成功的一半规则.要想被认为是伟大的投资者,你必须遵循以下的问题建议:"低价购买:再低价购买".每次你购买一支股 ...
- 洛谷P1244 青蛙过河 DP/思路
又是一道奇奇怪怪的DP(其实是思路题). 原文戳>>https://www.luogu.org/problem/show?pid=1244<< 这题的意思给的挺模糊,需要一定的 ...
- 洛谷 P2657 (数位DP)
### 洛谷 P2657 题目链接 ### 题目大意:给你一个数的范围 [A,B] ,问你这段区间内,有几个数满足如下条件: 1.两个相邻数位上的数的差值至少为 2 . 2.不包含前导零. 很简单的数 ...
- 洛谷 Golden Sword(dp,优先队列优化【含板子】)|| 补充练习:洛谷 跳房子
题目链接: 「SWTR-03」Golden Sword - 洛谷 思路: 设表示放第i个原料,锅里共有 j 个时的耐久度之和. 容易知道dp方程为,其中 这样就可以写出暴力dp的代码如下:(需要枚举i ...
最新文章
- python自动化框架pytest pdf_pytest+python下的UI自动化基础框架
- 基于kryo序列化方案的memcached-session-manager多memcached...
- 把我坑惨的一个update语句!
- 前谷歌董事长施密特:美国AI领导地位岌岌可危,科研预算投入得翻倍
- 视觉直观感受7种常用排序算法
- 如何解决div层被flash遮盖的问题
- 神策 2021 数据驱动大会嘉宾阵容首曝 + 精彩观点前瞻
- linux centos 编译luabind-0.9.1 动态库 静态库
- python第七天--字符串的方法与注释
- 这可能是 Python 面向对象编程的最佳实践
- 剑指offer(C++)-JZ34:二叉树中和为某一值的路径(二)(数据结构-树)
- 基于Ubuntu的ESP32平台搭建
- R语言开发软件包(打包)
- 稻盛和夫《活法》读书笔记
- android lut格式文件下载,一键调色?教你用Lut直接调出电影色调(内含下载)
- 一键加速去不掉加锁的_vivo手机一键加速的时候,怎样可以不把当前的应用清除?...
- 作为一个准研究生,怎样才能在研究生阶段不虚度?
- 大小端与高位先行、低位先行
- 你是我无法斑驳的阳光
- 2020牛客暑期多校训练营(第五场)题解
热门文章
- Mathematica图片局部变色
- 程序猿果真有前端后端client吗
- Linux下面的IO模型
- 49-今日交易总结.(2015.1.13)
- SharePoint2013安装组件时AppFabric时出现1603错误,解决方法:
- 简述WebService与.NET Remoting的区别及适应场合
- php resque 计划任务,PHP-RESQUE - 实现重试
- php gps 坐标,php 计算gps坐标 距离
- 在服务器中开虚拟机,可以在云服务器上开虚拟机
- java concurrent 例子_[Java Concurrent] 并发访问共享资源的简单案例