⭐ 欢迎来到虫虫下载站! | 📦 资源下载 📁 资源专辑 ℹ️ 关于我们
⭐ 虫虫下载站

📄 pku1088.cpp

📁 poj1088原代码, 这是最新的版本, 经过我们dhuACM团队合作而编写的!
💻 CPP
字号:
Problem Id:1088  User Id:lnmm 
Memory:152K  Time:0MS
Language:C++  Result:Accepted

 1#include"stdio.h"
 2const int dx[]={-1,0,1,0},dy[]={0,1,0,-1};
 3int r,c;//r和c分别是行和列
 4int node[101][101]; //放置每个坐标上的高度
 5int opt[101][101]; //放置从每个坐标出发的最优解
 6
 7bool ok(int i,int j)
 8{
 9  return (i>=1 && i<=r && j>=1 &&j<=c);
10}
11
12
13
14int dp(int i,int j)
15{
16    int k;
17    if(opt[i][j]>0) return opt[i][j];    //如果已经计算出,直接返回
18    for(k=0;k<4;k++)                    //向四个方向延伸
19    {
20        if(ok(i+dx[k],j+dy[k]))          //如果节点没有超出边界
21            if( node[i+dx[k]][j+dy[k]]<node[i][j] )        //满足滑雪条件
22            {
23                if(  opt[i][j]< dp(i+dx[k],j+dy[k])+1 ) 
24                         opt[i][j]=dp(i+dx[k],j+dy[k])+1;
25            }
26    }
27    return opt[i][j];
28
29
30//       if(ok(i+dx[k],j+dy[k])&&node[i+dx[k]][j+dy[k]]<node[i][j]&&opt[i][j]>dp(i+dx[k],j+dy[k])+1)
31//           opt[i][j]=dp(i+dx[k],j+dy[k])+1;
32
33     
34
35}
36
37void main()
38{
39    int max=0,i,j; 
40    scanf("%d%d",&r,&c);
41
42    for(i=1;i<=r;i++)
43        for(j=1;j<=c;j++)
44            scanf("%d",&node[i][j]);
45   for(i=1;i<=r;i++)
46        for(j=1;j<=c;j++)
47         opt[i][j]=0;
48
49    for(i=1;i<=r;i++)
50        for(j=1;j<=c;j++)
51            if(max<dp(i,j))max=dp(i,j);
52    printf("%d",max+1);  //输出值需要+1 ,因为在前面的计算中,每个点的初始值都是0
53
54    return ;
55}
56

⌨️ 快捷键说明

复制代码 Ctrl + C
搜索代码 Ctrl + F
全屏模式 F11
切换主题 Ctrl + Shift + D
显示快捷键 ?
增大字号 Ctrl + =
减小字号 Ctrl + -