dp2接上一篇

简介:


nefu 18 题 滑雪(经典dp)我感觉在hdu上也应该能找到

description

 
每到冬天,信息学院的张老师总爱到二龙山去滑雪,喜欢滑雪百这并不奇怪, 因为滑雪的确很刺激。可是为了获得速度,滑的区域必须向下倾斜,而且当你滑到坡底,你不得不再次走上坡或者等待升降机来载你。张老师想知道载一个区域中最长底滑坡。区域由一个二维数组给出。数组的每个数字代表点的高度。

input

 
输入的第一行表示区域的行数R和列数C(R,C>=1&&R<C<=100)。下面是R行,每行有C个整数,代表高度h(h>=0&&h<=10000)

output

 
输出最长区域的长度。

sample_input

 
5 5
1 2 3 4 5
16 17 18 19 6
15 24 25 20 7
14 23 22 21 8
13 12 11 10 9
一个人可以从某个点滑向上下左右相邻四个点之一,当且仅当高度减小。在上面的例子中,
一条可滑行的滑坡为24-17-16-1。当然25-24-23-...-3-2-1更长。
事实上,这是最长的一条。

sample_output

 
25
 
 
 
 
 
 
 
 
 
 
代码如下:(自己编的,不是太规范,请见谅)
#include <iostream>
#include <cstring>
#include <cstdio>
using namespace std;
int dp[105][105];
int data[105][105];
int m,n;
int Find(int i,int j)
{
    int max1,max2;
    int l=0,r=0,u=0,d=0;
    if(dp[i][j]>0)return dp[i][j];
    if(j+1<=n&&data[i][j]>data[i][j+1])//找右边的最大值
    r=Find(i,j+1);
    if(j-1>=1&&data[i][j-1]<data[i][j])//找左边的最大值
    l=Find(i,j-1);
    if(i+1<=m&&data[i][j]>data[i+1][j])//找上边的最大值
    u=Find(i+1,j);
    if(i-1>=1&&data[i][j]>data[i-1][j])//找下边的最大值
    d=Find(i-1,j);
    max1=max(r,l);
    max2=max(u,d);
    dp[i][j]=max(max1,max2)+1;//找最终的最大值
    return dp[i][j];
}
int main()
{
   while(~scanf("%d%d",&m,&n))
   {
      for(int i=1;i<=m;i++)
      for(int j=1;j<=n;j++)
      scanf("%d",&data[i][j]);
      int k=0;
      for(int i=1;i<=m;i++)
      {
          for(int j=1;j<=n;j++)
          {
              k=Find(i,j);
          }
      }
      int max1=-9999999;
      for(int i=1;i<=m;i++)
      {
          for(int j=1;j<=n;j++)
          {
              if(max1<dp[i][j])
              max1=dp[i][j];
          }
      }
      printf("%d\n",max1);
   }
    return 0;
}
 

目录
相关文章
|
9月前
流(树形dp,换根dp)
流(树形dp,换根dp)
46 0
|
存储 机器学习/深度学习 Web App开发
秒懂算法 | DP 概述和常见 DP 面试题
动态(DP)是一种算法技术,它将大问题分解为更简单的子问题,对整体问题的最优解决方案取决于子问题的最优解决方案。本篇内容介绍了 DP 的概念和基本操作;DP 的设计、方程推导、记忆化编码、递推编码、滚动数组以及常见的 DP 面试题。
524 0
秒懂算法 | DP 概述和常见 DP 面试题
|
存储 算法
dp 就 dp ,数位dp是什么意思 ?
dp 就 dp ,数位dp是什么意思 ?
412 0
|
算法 C++
算法精品讲解(2)——DP问题入门(适合零基础者,一看就会)
到目前为止,我们也已经讲解了几个例题了。我们在最后,就不再为大家继续讲解新的例题了。理由很简单,因为动态规划的题目是有规律可循的,可以将其按照知识点,或者是按照题型归类。而笔者将会在下一篇姊妹篇中,为大家带来按照知识点来讲解的动态规划。而动态规划的提醒大家可以通过多多做一些练习,并将其加以总结,就会对这一块有着越来越深刻的印象和认识。本篇文章的定位只是帮助大家认识DP,将大家领进门,还远远没有能够达到能够熟练掌握的地步。但是大家至少在看完本篇文章之后,能够对所有的DP问题有着清晰的架构了,并且在之后看题解的过程中、做题的过程中也会有自己的一些套路和思考在了。不至于一窍不通、是一个门外汉了。
228 0
算法精品讲解(2)——DP问题入门(适合零基础者,一看就会)
|
数据安全/隐私保护
蓝桥杯第十五讲--复杂dp【例题】(二)
蓝桥杯第十五讲--复杂dp【例题】
159 0
蓝桥杯第十五讲--复杂dp【例题】(二)
|
算法 数据安全/隐私保护 C++
蓝桥杯第十五讲--复杂dp【例题】(一)
蓝桥杯第十五讲--复杂dp【例题】
157 0
蓝桥杯第十五讲--复杂dp【例题】(一)
|
算法 C++
蓝桥杯第十五讲--复杂dp【习题】
蓝桥杯第十五讲--复杂dp【习题】
274 0
蓝桥杯第十五讲--复杂dp【习题】
|
存储 容器
一题四解 : 「DFS」&「记忆化搜索」&「全量 DP」&「优化 DP」
一题四解 : 「DFS」&「记忆化搜索」&「全量 DP」&「优化 DP」

热门文章

最新文章