第一版请见:直通

话不多说,直接上题

1.P1040 加分二叉树

直通

思路:

  已知中序遍历,相当于一段区间了,所以我们枚举一个k,如果以k为根节点,能够将分数更新,那么这段区间的根节点就置为k,最后dp[1][n]就是得分;

  核心代码:

	for(int i=n-1; i>=1; i--)
for(int j=i+1; j<=n; j++)
for(int k=i; k<=j; k++)
if(dp[i][k-1]*dp[k+1][j]+a[k]>dp[i][j])
p[i][j]=k,dp[i][j]=dp[i][k-1]*dp[k+1][j]+a[k];

坑点:

  别忘了dp数组的初始值为1,不然会“爆零”

上代码:

#include <iostream>
#include <cstdio>
using namespace std; const int M = ;
int n;
int a[M],p[M][M],dp[M][M]; void print(int l,int r) {
if(l>r) return;
printf("%d ",p[l][r]);
print(l,p[l][r]-);
print(p[l][r]+,r);
} int main() {
scanf("%d",&n);
for(int i=; i<=n; i++)
for(int j=; j<=n; j++)
dp[i][j]=;
for(int i=; i<=n; i++) {
scanf("%d",&a[i]);
dp[i][i]=a[i];
p[i][i]=i;
}
for(int i=n-; i>=; i--)
for(int j=i+; j<=n; j++)
for(int k=i; k<=j; k++)
if(dp[i][k-]*dp[k+][j]+a[k]>dp[i][j])
p[i][j]=k,dp[i][j]=dp[i][k-]*dp[k+][j]+a[k];
printf("%d\n",dp[][n]);
print(,n);
return ;
}

2.P1052 过河

直通

思路:

  枚举左端点i,能够跳的步数j,以及st数组(存储是否有石头)

      那么转移方程就是:

        dp[i]=min(dp[i],dp[i-j]+st[i]);

  又因为是取min,所以需要进行初始化

坑点:

  题目中说道:当青蛙跳到或跳过坐标为L的点时,就算青蛙已经跳出了独木桥

  所以我们最后进行输出的时候不能够只输出dp[l],而要在dp[l~l+t]之间进行取min

上代码:

#include <iostream>
#include <cstdio>
#include <cmath>
#include <cstring>
#include <algorithm>
using namespace std; const int Mod = ; //1~10的最小公倍数,是路径压缩的关键!
//因为2520步是它们的倍数,所以一定会直接跳过去,不用管是用多么大的步数跳的
const int L = ;
int l,s,t,m,ans;
int a[L],y[L],st[L],dp[L];
//y[] : 压缩后每块石子之前需要跳的步数 int main() {
scanf("%d%d%d%d",&l,&s,&t,&m);
ans=m; //最多跳过m块石头
for(int i=; i<=m; i++) scanf("%d",&a[i]);
sort(a+,a++m);
for(int i=; i<=m; i++) y[i]=(a[i]-a[i-])%Mod; //状压
for(int i=; i<=m; i++) a[i]=a[i-]+y[i],st[a[i]]=; //重新将a进行赋值,并标记石头
l=a[m]; //更新l值
for(int i=; i<=l+m; i++) dp[i]=m; //赋对于该题来说的最大值m
dp[]=; //起点处不含石头
for(int i=s; i<l+t; i++)
for(int j=s; j<=t; j++) //枚举跳的步数
if(i-j>=) dp[i]=min(dp[i],dp[i-j]+st[i]); //dp转移方程
for(int i=l; i<l+t; i++) ans=min(ans,dp[i]); //最远跳到l+t
printf("%d",ans);
return ;
}

DP(第二版)的更多相关文章

  1. 计算机视觉与模式识别代码合集第二版three

    计算机视觉与模式识别代码合集第二版three     Topic Name Reference code Optical Flow Horn and Schunck's Optical Flow   ...

  2. 读书笔记:JavaScript DOM 编程艺术(第二版)

    读完还是能学到很多的基础知识,这里记录下,方便回顾与及时查阅. 内容也有自己的一些补充. JavaScript DOM 编程艺术(第二版) 1.JavaScript简史 JavaScript由Nets ...

  3. 《selenium2 Java 自动化测试实战(第二版)》 更新2016.5.3

    java 版来了!! 本文档在<selenium2 Python 自动化测试实战>的基础上,将代码与实例替换为java ,当然,部分章节有变更.这主要更语言本身的特点有关.集合和java下 ...

  4. 《Java程序设计与数据结构教程(第二版)》学习指导

    <Java程序设计与数据结构教程(第二版)>学习指导 欢迎关注"rocedu"微信公众号(手机上长按二维码) 做中教,做中学,实践中共同进步! 原文地址:http:// ...

  5. (转载)持续集成(第二版)[来自:Martin Fowler]

    转载自:iTech的博客 持续集成(第二版) 作者:Martin Fowler 译者:雷镇 持续集成 是一种软件开发实践.在持续集成中,团队成员频繁集成他们的工作成果,一般每人每天至少集成一次,也可以 ...

  6. Learning ROS for Robotics Programming - Second Edition(《学习ROS机器人编程-第二版》)

    Learning ROS for Robotics Programming - Second Edition <学习ROS机器人编程-第二版> ----Your one-stop guid ...

  7. Lucene.net站内搜索—6、站内搜索第二版

    目录 Lucene.net站内搜索—1.SEO优化 Lucene.net站内搜索—2.Lucene.Net简介和分词Lucene.net站内搜索—3.最简单搜索引擎代码Lucene.net站内搜索—4 ...

  8. android 常用小功能(第二版)

    经历过一段岁月,转眼2013的半年都过去了,第二版整理好的小功能,答应大家发布的,直到今日,终于和大家相见了,第二版没有第一版多,大家也可以去参考第一版的内容,希望大家使用愉快! 目录: 1.获取当前 ...

  9. selenium webdriver (python) 第二版

    前言 对于大多软件测试人员来讲缺乏编程经验(指项目开发经验,大学的C 语言算很基础的编程知识)一直是难以逾越的鸿沟,并不是说测试比开发人员智商低,是国内的大多测试岗位是功能测试为主,在工作时间中,我们 ...

  10. J2msi 自己制作的把exe打成安装包简易GUI程序(第二版 带DLL注册)

    J2msi 自己制作的把exe打成安装包简易GUI程序(第二版 带DLL注册) 之前那一版本(http://www.cnblogs.com/rojas/p/4794684.html)没考虑 DLL 注 ...

随机推荐

  1. 关于OI中的各种数学

    学到后面数学越来越多了,感觉好难啊,开个博客专门记录一下数学相关的东西 因为反正也没人看,所以主要还是给自己看的 一些符号: 数论函数的卷积:$\ast$,$ h = f \ast g$ 则 $h(n ...

  2. MySQL 触发器的使用

    MySQL 基础篇 三范式 MySQL 军规 MySQL 配置 MySQL 用户管理和权限设置 MySQL 常用函数介绍 MySQL 字段类型介绍 MySQL 多列排序 MySQL 行转列 列转行 M ...

  3. C#获取客户端Ip工具类

    string pcname = Dns.GetHostName(); string ip = Dns.GetHostAddresses(pcname).First().ToString(); usin ...

  4. HTML中关于动态创建的标签无法绑定js事件的解决方法:.on()方法的 [.selector]

    在前端页面的时候,会经常遇到用JavaScript动态创建出来的Button按钮或其他标签无法使用点击事件的问题.如下代码,使用jquery在body中动态创建一个class为demo的Button按 ...

  5. (十一)Hibernate中的多表操作(1):单向一对多

    一.单向一对多() 案例一(用XML文件配置): 一个班级有多个学生,班级可以查看所有学生的信息. ClassBean.java package bean; import java.util.Hash ...

  6. Uwl.Admin开源框架(一)

    1.前言 作为一个忠实的软粉,一直期待微软出跨平台,一直在等待.Net Core,因为刚毕业对于.Net的很多东西不是很熟知,就开始了.Net Core的摸索,一路上坎坎坷坷,对于新技术一直很期待,就 ...

  7. kong网关命令(一)

    上次在虚拟机里安装kong网关后,因为版本(1.4)太高,目前Kong Dashboard无法支持, 后续发现Git上有个开源工具Kong admin ui,下载源码并部署到NGINX. 但是发现使用 ...

  8. win10下PLSQL Developer 连接ubuntu上安装的oracle 11g

    说明:过程记录的不是很相信,只记录基本步骤.并不适合想一步一步照做的同学. win10下需要的操作 1.微软官网下载instantclient,然后接到到本地一个文件夹,注意路径不要又空格,中文和括号 ...

  9. springboot2.0介绍1

    SpringBoot 一. Spring介绍 1.1.SpringBoot简介 在您第1次接触和学习Spring框架的时候,是否因为其繁杂的配置而退却了?在你第n次使用Spring框架的时候,是否觉得 ...

  10. js如何获取数值

    获取jsfunction返回的值1,首先,用初始化代码创建一个新的HTML5文件,如下所示.2,创建一个新的H1标记来接收JS中函数休闲鹿的返回值.3,创建一个新的脚本标记并在标记中创建一个新函数.函 ...