题目链接:P1006 传纸条

PS:伤心,又想不出来,看了大神的题解

AC代码:

#include<bits/stdc++.h>
#define ll long long
using namespace std;
ll n,m,f[][],a[][];
int main()
{
ll i,j,k;
cin>>n>>m;
for (i=;i<=n;++i)
for (j=;j<=m;++j)
cin>>a[i][j]; f[][]=a[][]+a[][];//不管怎样都会经过(1,2)和(2,1)先赋初值
//i是当前的点横纵坐标之和
//下面的循环是起码2*3或者3*2棋盘才会进入,如果2*2及以下棋盘已经初定义了
for (i=;i<n+m;++i)//至于i<n+m我是画草图才理解的
{
for (j=min(i-,n);j>=;j--) //滚动数组,i层和i-层有关,所以j,k要一直减小而不是增大,防止数据覆盖
{//j=min(i-2,n)是在不超出的情况下找尽量小的能走的位置
for (k=min(i-,n);k>j;k--)
{//k在j右边,所以是i-1
if (j>) //这里的条件判断貌似是不需要的,但加上更好
{
f[j][k]=max(f[j][k],f[j-][k]);
}
if (j>&&k>)
{
f[j][k]=max(f[j][k],f[j-][k-]);
}
if (k->j)//保证移动前的点没有重合
{
f[j][k]=max(f[j][k],f[j][k-]);
}
//对于两个都从上边来的,其实是另一对(j,k)的两个都从左边来,所以不用写了
f[j][k]+=a[j][i-j]+a[k][i-k];//把数字带上
}
}
} cout<<f[n-][n];//输出左下角左边和上边两个格的数字和就好了 return ;
}

点击加号展开代码

谈谈我对这个思路的理解:

1.我们可以看成两纸条同时从左上角原点出发

2.我们发现对于一个画一条条斜线,斜线上的每个点横坐标加纵坐标的和都相同

而且原点到同一条线上任意点要走的距离相同,那么每走一步,纸条a和纸条b都在一条斜线上

为了防止相遇,我们可以假设b的横坐标k永远大于a的横坐标j

而且,我们用i=n+m,那么任意一点的横坐标=i-纵坐标,纵坐标同理,也就是横坐标+纵坐标=i=n+m

3.那我们用i的变化来表示他们现在走到哪条斜线了,

这样一来,就可以开始递推,而且i只和i-1有关系,这是用滚动数组的前提

4.对于数组f[j,k],我们可以看成a走到(j,i-j),b走到(k,i-k)时捡起的总数字

5.然后赋初值,一开始第一步肯定是一个向右,一个向下,所以:

 f[][]=a[][]+a[][];

不管怎样都会经过(1,2)和(2,1)先赋初值

6.循环如何实现

for (i=;i<n+m;++i)//至于i<n+m我是画草图才理解的
for (j=min(i-,n);j>=;j--)
//滚动数组,i层和i-层有关,所以j,k要一直减小而不是增大,防止数据覆盖
//j=min(i-2,n)是在不超出的情况下找尽量小的能走的位置
for (k=min(i-,n);k>j;k--)//k在j右边,所以是i-1

第一维for表示要递推的次数,从4开始是因为如果n,m为1,3就没意义了,而m,n为2,2就已经靠初始化就够了,不需要递推

第二维是考虑纸条a的递推,从大到小是因为每次都要用前面的数据赋值新的数据,所以这样能防止覆盖

第三维和第二维差不多

7.递推式

if (j>)  //这里的条件判断貌似是不需要的,但加上更好
{
f[j][k]=max(f[j][k],f[j-][k]);
}
if (j>&&k>)
{
f[j][k]=max(f[j][k],f[j-][k-]);
}
if (k->j)//保证移动前的点没有重合
{
f[j][k]=max(f[j][k],f[j][k-]);
}
//对于两个都从上边来的,其实是另一对(j,k)的两个都从左边来,所以不用写了

解释以下,这里分别代表

a从左来,b从左来

a从上来,b从左来

a从左来,b从上来

有人回问那两个都从上来去哪了?额,它其实在另外一个地方被算过了,下面上图解释

红色和蓝色表示两个都从上面来,其实他们就等于黄色的那两个地方的两个都从左边来

还有一个地方要注意的是:a从上来,b从左来,这时候要k-1>j,保证移动前的两个点不是重合的

下面上个图解释一下,下图是错误情况

8.输出结果,只要输出当a,b到最右下角那个点的左边和上面的情况的值就好了

老是写不出来DP,自闭了...

NOIP 2008 传纸条(洛谷P1006,动态规划递推,滚动数组)的更多相关文章

  1. 最大子段和(洛谷P1115,动态规划递推)

    洛谷题目链接 题目赋值出来格式有问题,所以我就只放题目链接了 下面为ac代码 #include<bits/stdc++.h> #define ll long long using name ...

  2. P1006 传纸条-洛谷luogu-dp动态规划

    题目描述 小渊和小轩是好朋友也是同班同学,他们在一起总有谈不完的话题.一次素质拓展活动中,班上同学安排做成一个mm行nn列的矩阵,而小渊和小轩被安排在矩阵对角线的两端,因此,他们就无法直接交谈了.幸运 ...

  3. AC日记——传纸条 洛谷 P1006

    题目描述 小渊和小轩是好朋友也是同班同学,他们在一起总有谈不完的话题.一次素质拓展活动中,班上同学安排做成一个m行n列的矩阵,而小渊和小轩被安排在矩阵对角线的两端,因此,他们就无法直接交谈了.幸运的是 ...

  4. NOIP 2006 金明的预算方案(洛谷P1064,动态规划递推,01背包变形,滚动数组)

    一.题目链接:P1064 金明的预算方案 二.思路 1.一共只有五种情况 @1.不买 @2.只买主件 @3.买主件和附件1(如果不存在附件也要运算,只是这时附件的数据是0,也就是算了对标准的结果也没影 ...

  5. Luogu 1006 传纸条 / NOIP 2008 传纸条(动态规划)

    Luogu 1006 传纸条 / NOIP 2008 传纸条(动态规划) Description 小渊和小轩是好朋友也是同班同学,他们在一起总有谈不完的话题.一次素质拓展活动中,班上同学安排做成一个m ...

  6. noip 2008 传纸条

    题目描述 小渊和小轩是好朋友也是同班同学,他们在一起总有谈不完的话题.一次素质拓展活动中,班上同学安排做成一个m行n列的矩阵,而小渊和小轩被安排在矩阵对角线的两端,因此,他们就无法直接交谈了.幸运的是 ...

  7. NOIP 2008 传纸条 NOIP 2000 方块取数 多线程DP

    思路都是一样,建立一个四维dp然后跑一发就完了 当然,也可以像我这么帅的人,降成三维再傻傻的跑一发啦啦啦~ #include<iostream> #include<stdio.h&g ...

  8. 最长上升子序列(动态规划递推,LIS)

    1759:最长上升子序列 题目: 总时间限制: 2000ms 内存限制: 65536kB 描述 一个数的序列bi,当b1 < b2 < ... < bS的时候,我们称这个序列是上升的 ...

  9. 洛谷P1006 NOIP提高组2008 传纸条

    P1006 传纸条 题目描述 小渊和小轩是好朋友也是同班同学,他们在一起总有谈不完的话题.一次素质拓展活动中,班上同学安排做成一个m行n 列的矩阵,而小渊和小轩被安排在矩阵对角线的两端,因此,他们就无 ...

随机推荐

  1. 通过spark rdd 求取 特征的稀疏向量

    通过spark rdd 求取  特征的稀疏向量 spark 类标签的稀疏 特征向量 - bonelee - 博客园 http://www.cnblogs.com/bonelee/p/7814081.h ...

  2. JTabbedPane的LookAndFeel--TabbedPaneUI

    在定制JTabbedPane的时候是需要使用到LookAndFeel的,而使用LookAndFeel定制的时候,其实主要是继承BasicTabbedPaneUI. to be continue...

  3. Hierarchyviewer定位Android图片资源的研究

    之前就在研究能否通过Hierarchyviewer找到所有所见的资源 在导入Hierarchyviewer之后才发现绑定在View上的drawable与实际的图片资源之间并没有维系着一个固定的对应关系 ...

  4. 【ZJOI2009】【Codevs 2347】假期的宿舍

    http://codevs.cn/problem/2347/ Solution 二分图板子 连边:i认识j并且j是在校有床 i→j+n i有床i→i+n 还有就是找要在学校的人,1.有床不回2.没床的 ...

  5. Android下载资源

    下面提供了源码下载地址,供有兴趣的朋友下载, android音乐播放器源码   由于本人才疏学浅,有很多地方不够完善,希望大家指证. 免费下载地址在 http://linux.linuxidc.com ...

  6. Akka源码分析-Akka-Streams-概念入门

    今天我们来讲解akka-streams,这应该算akka框架下实现的一个很高级的工具.之前在学习akka streams的时候,我是觉得云里雾里的,感觉非常复杂,而且又难学,不过随着对akka源码的深 ...

  7. 【题解】自行车比赛 [AHOI2016] [P2777]

    [题解]自行车比赛 \([AHOI2016]\) \([P2777]\) 逼自己每天一道模拟题 传送门:自行车比赛 \([AHOI2016]\) \([P2777]\) [题目描述] 比赛中一共有 \ ...

  8. restful api 错误

    简介 随着移动开发和前端开发的崛起,越来越多的 Web 后端应用都倾向于实现 Restful API.Restful API 是一个简单易用的前后端分离方案,它只需要对客户端请求进行处理,然后返回结果 ...

  9. centos 扩展lrzsz通过xshell 下载安装文件

    yum自动安装: yum install lrzsz 手动安装方法如下: 定制安装的linux可能没有把rzsz包安装到系统,这对用securecrt这样的windows工具传输文件特别不方便.为了使 ...

  10. random模块思维导图