zoukankan      html  css  js  c++  java
  • POJ1088 (滑雪)

    试了一下深搜每个节点结果TLE了

    突然发现是个很明显的DP

    从最小的节点开始,更新它四周的节点,如果存在比它高度高的节点,高的节点步数 + 1,因为节点的更新状态肯定是比它高度低那获取的,因此更新时四周比它低的节点已经确定了是最大步数了

    // #include<iostream>//POJ 1088滑雪
    // #include<cstdio>//深搜试每条路径
    // #include<cstring>
    // #include<algorithm>
    // using namespace std;
    // const int maxn = 100 + 15;//地图
    // bool vis[maxn][maxn];//判断每个节点是否访问过
    // int Map[maxn][maxn];//地图
    // int maxLen = 0;//最长路径
    // int arrx[] = {1,-1,0,0};
    // int arry[] = {0,0,1,-1};
    // int R,C;//R代表行数,C代表列数
    // void dfs(int x,int y,int len)//从 pos(x,y)坐标开始搜索,len为当前步数
    // {
    //     maxLen = max(len,maxLen);
    //     vis[x][y] = true;//表示坐标已访问过
    //     int newx,newy;//新坐标的x,y位置
    //     for(int i=0;i!=4;++i)
    //     {
    //         newx = x + arrx[i];
    //         newy = y + arry[i];//新位置
    //         if(vis[newx][newy])
    //             continue;
    //         if(newx<0||newx>=R||newy<0||newy>=C)
    //             continue;//防止越界
    //         if(Map[newx][newy] < Map[x][y])
    //             dfs(newx,newy,len+1);
    //         vis[newx][newy] = false;//回溯
    //     }
    // }
    // int main()
    // {
    //     while(cin>>R>>C)
    //     {
    //         for(int i=0;i!=R;++i)
    //         {
    //             for(int j=0;j!=C;++j)
    //                 cin>>Map[i][j];//输入地图
    //         }
    //         for(int i=0;i!=R;++i)
    //         {
    //             for(int j=0;j!=C;++j)
    //             {//从每个点开始尝试
    //                 memset(vis,false,sizeof(vis));//重置访问地图
    //                 dfs(i,j,1);
    //             }
    //         }
    //         cout<<maxLen<<endl;
    //     }
    // }
    ////////////////动规(动态规划)
    #include<iostream>
    #include<cstdio>
    #include<vector>
    #include<algorithm>
    using namespace std;//经典DP
    int R,C;//R代表行,C代表列
    const int maxn = 100 + 15;
    int Map[maxn][maxn];//地图(储存每个点的值)
    int cnt[maxn][maxn];
    typedef struct
    {
        int x,y;//x代表行,y代表列
        int h;//高度
    }node;//每个节点代表位置
    vector<node> v;
    bool cmp(const node& n1,const node& n2)
    {
        return n1.h < n2.h;
    }
    int arrx[] = {1,-1,0,0};
    int arry[] = {0,0,1,-1};
    int main()//我为人人DP
    {
        while(cin>>R>>C)
        {
            node tmp;
            for(int i=0;i!=R;++i)
            {
                for(int j=0;j!=C;++j)
                {
                    cnt[i][j] = 1;//初始化步数为1
                    tmp.x = i;
                    tmp.y = j;
                    cin>>tmp.h;
                    Map[i][j] = tmp.h;
                    v.push_back(tmp);
                }
            }
            //从小到大排序(h)
            sort(v.begin(),v.end(),cmp);
            for(int i=0;i!=R*C;++i)//对于每个节点
            {
                for(int j=0;j!=4;++j)
                {
                    int newx = v[i].x + arrx[j];
                    int newy = v[i].y + arry[j];
                    if(newx<0||newx>=R||newy<0||newy>=C)
                        continue;//防止越界
                    if(Map[newx][newy] > v[i].h)
                        cnt[newx][newy] = max(cnt[newx][newy],cnt[v[i].x][v[i].y]+1);
                }
            }
            int maxlen = 0; 
            for(int i=0;i!=R;++i)
            {
                for(int j=0;j!=C;++j)
                    maxlen = max(maxlen,cnt[i][j]);
            }
            cout<<maxlen<<endl;
        }
    }
    不怕万人阻挡,只怕自己投降。
  • 相关阅读:
    7/31 CSU-ACM2018暑期训练7-贪心
    树状数组
    洛谷 P2947 [USACO09MAR]向右看齐Look Up【单调栈】
    如何求先序排列和后序排列——hihocoder1049+洛谷1030+HDU1710+POJ2255+UVA548【二叉树递归搜索】
    HDU 1611 敌兵布阵【线段树模板】
    Poj 2112 Optimal Milking (多重匹配+传递闭包+二分)
    Hdu 5361 In Touch (dijkatrs+优先队列)
    Codeforces Round #Pi (Div. 2)
    Hdu 5358 First One (尺取法+枚举)
    Poj 3189 Steady Cow Assignment (多重匹配)
  • 原文地址:https://www.cnblogs.com/newstartCY/p/11460856.html
Copyright © 2011-2022 走看看