这名字听起来实在有点耳熟。。?

好吧去年暑假就应该过的题。。。切了

先注意到,天使施魔法的次数不限;我们可以使得某个时刻在特定方向移动一段距离(最长的长度为那个时间段)然后怎么来考虑这个DP;

T,X,Y三维状态很好想到,刚开始的时刻是1,T-1的方向已知,要么从那个方向移动到X,Y,要么在此位置不动。现在来优化这个DP。我们的动机是把O(N*M*T)->O(N*M*K),至于为什么要这要做。。。(题感啊题感,所有的优化都是优化转移嘛不可能优化状态了,所以当转移都无法优化的时候我们只能考虑来改变这个状态。K是时间段的个数,可以想到,其实在同一时间段里面,操作几乎都是相同的。那么dp[K][X][Y]表示在K这段时间内,位于(X,Y)这个位置,从时段1到时段K的最大位移。那么转移就成为了:dp[K][X][Y]=MAX{dp[K-1][X'][Y']+DIST}

*举个例子,假如当前时间段朝向是往右,那么dp[k][x][y]=max{dp[k-1][x][y-Δy]+Δy}=y+max{dp[k-1][x][y']-y'},Δy自然要小于等于当前时间段的长度。现在转移就可以被优化了,我们把k-1时间段的状态记载下来,保证单调递减就OK了,其它三个方向也是类似的:

left:dp[k][x][y]=max{dp[k-1][x][y']+y'}-y

up:dp[k][x][y]=max(dp[k-1][x'][y]+x'}-x

down:dp[k][x][y]=max(dp[k-1][x'][y]-x'}+x

在执行队列的过程中我们有几个需要维护的地方,如果当前自己是家具,那么没关系,我们清空队列;

如果要放进的那个是不合法的,那就不放。

CODE:

#include<cstdio>
#include<cstring>
#include<algorithm>
#define N 300
using namespace std;
int n,m,x0,y0,k,ans;
][][];
];
int main()
{
    ];
    scanf("%d%d%d%d%d",&n,&m,&x0,&y0,&k);
    ;i<=n;i++)
    {
        scanf("%s",s);
        ;j<=m;j++)
         ]==;
    }
    ;i<=k;i++)scanf("%d%d%d",&st[i],&ed[i],&ff[i]);
    memset(dp,-,sizeof(dp));
    dp[][x0][y0]=;
    ;i<=k;i++)
    {
       );
       ){//向右
       ;xx<=n;xx++)
        {
          ,tail=;q[].x=dp[i-][xx][]-;q[].h=;
          ][xx][]==-)tail--;
          ;yy<=m;yy++)
          {
              while(tou<=tail&&(yy-q[tou].h>len))tou++;
              )if(tou<=tail)dp[i][xx][yy]=q[tou].x+yy;
              //if(dp[i][xx][yy]>-1)printf("you===%d %d %d %d %d\n",i,xx,yy,dp[i][xx][yy],q[tou].h);
              ){tail=tou-;}
              ][xx][yy+]==-)continue;
                ][xx][yy+]-yy->q[tail].x)tail--;
                tail++;q[tail].x=dp[i-][xx][yy+]-yy-;q[tail].h=yy+;
          }
        }
       }
      )//left
      {
         ;xx<=n;xx++)
         {
             ,tail=;q[].x=dp[i-][xx][m]+m;q[].h=m;
             ][xx][m]==-)tail--;
             ;yy--)
             {
                 while(tou<=tail&&q[tou].h-yy>len)tou++;
                 )if(tou<=tail)dp[i][xx][yy]=q[tou].x-yy;
                 //if(dp[i][xx][yy]>-1)printf("zuo===%d %d %d %d %d\n",i,xx,yy,dp[i][xx][yy],q[tou].h);
                 )tail=tou-;
                 ][xx][yy-]==-)continue;
                 ][xx][yy-]+yy->q[tail].x)tail--;
                 tail++;q[tail].x=dp[i-][xx][yy-]+yy-;q[tail].h=yy-;
             }
         }
      }
      )//向上
      {
          ;yy<=m;yy++)
          {
              ,tail=;q[].x=dp[i-][n][yy]+n;q[].h=n;
              ][n][yy]==-)tail--;
              ;xx--)
              {
                  while(tou<=tail&&q[tou].h-xx>len)tou++;
                  )if(tou<=tail)dp[i][xx][yy]=q[tou].x-xx;
                   //if(dp[i][xx][yy]>-1)printf("up===%d %d %d %d %d\n",i,xx,yy,dp[i][xx][yy],q[tou].h);
                  )tail=tou-;
                  ][xx-][yy]==-)continue;
                  ][xx-][yy]+xx->q[tail].x)tail--;
                  tail++;q[tail].x=dp[i-][xx-][yy]+xx-;q[tail].h=xx-;
              }
          }
      }
      )//xia
      {
          ;yy<=m;yy++)//down
          {
              ,tail=;q[].x=dp[i-][][yy]-;q[].h=;
              ][][yy]==-)tail--;
              ;xx<=n;xx++)
              {
                  while(tou<=tail&&xx-q[tou].h>len)tou++;
                  )if(tou<=tail)dp[i][xx][yy]=q[tou].x+xx;
                  //if(dp[i][xx][yy]>-1)printf("xia===%d %d %d %d %d\n",i,xx,yy,dp[i][xx][yy],q[tou].h);
                  )tail=tou-;
                  ][xx+][yy]==-)continue;
                  ][xx+][yy]-xx->q[tail].x)tail--;
                  tail++;q[tail].x=dp[i-][xx+][yy]-xx-;q[tail].h=xx+;
              }
          }
      }
    }
    ;i<=n;i++)
     ;j<=m;j++)
      if(dp[k][i][j]>ans)ans=dp[k][i][j];
      //printf("%d %d %d\n",i,j,dp[k][i][j]);
   printf("%d",ans);
} 

【bzoj1499】瑰丽华尔兹的更多相关文章

  1. 洛谷2254 BZOJ1499 瑰丽华尔兹题解

    洛谷链接 BZ链接 一个很容易想到的做法就是用f[i][j][t]表示t时刻在i,j处的可以滑动的最大值 f[i][j][t]=max(f[i][j][t-1],f[*i][*j][t-1]),这样大 ...

  2. 【BZOJ1499】瑰丽华尔兹(动态规划)

    [BZOJ1499]瑰丽华尔兹(动态规划) 题面 BZOJ 题解 先写部分分 设\(f[t][i][j]\)表示当前在\(t\)时刻,位置在\(i,j\)时走的最多的步数 这样子每一步要么停要么走 时 ...

  3. 【BZOJ1499】【NOI2005】瑰丽华尔兹(动态规划)

    [BZOJ1499]瑰丽华尔兹(动态规划) 题面 BZOJ 题解 先写部分分 设\(f[t][i][j]\)表示当前在\(t\)时刻,位置在\(i,j\)时走的最多的步数 这样子每一步要么停要么走 时 ...

  4. 【BZOJ1499】[NOI2005]瑰丽华尔兹 单调队列+DP

    [BZOJ1499][NOI2005]瑰丽华尔兹 Description 你跳过华尔兹吗?当音乐响起,当你随着旋律滑动舞步,是不是有一种漫步仙境的惬意?众所周知,跳华尔兹时,最重要的是有好的音乐.但是 ...

  5. bzoj1499[NOI2005]瑰丽华尔兹 单调队列优化dp

    1499: [NOI2005]瑰丽华尔兹 Time Limit: 3 Sec  Memory Limit: 64 MBSubmit: 1802  Solved: 1097[Submit][Status ...

  6. [Bzoj1499][NOI2005]瑰丽华尔兹[简单DP]

    1499: [NOI2005]瑰丽华尔兹 Time Limit: 3 Sec  Memory Limit: 64 MBSubmit: 1714  Solved: 1042[Submit][Status ...

  7. DP+单调队列 codevs 1748 瑰丽华尔兹(还不是很懂具体的代码实现)

    codevs 1748 瑰丽华尔兹 2005年NOI全国竞赛  时间限制: 1 s  空间限制: 128000 KB  题目等级 : 大师 Master 题解       题目描述 Descripti ...

  8. NOI2005瑰丽华尔兹

    1499: [NOI2005]瑰丽华尔兹 Time Limit: 3 Sec  Memory Limit: 64 MBSubmit: 893  Solved: 508[Submit][Status] ...

  9. BZOJ 1499 [NOI2005] 瑰丽华尔兹 | 单调队列优化DP

    BZOJ 1499 瑰丽华尔兹 | 单调队列优化DP 题意 有一块\(n \times m\)的矩形地面,上面有一些障碍(用'#'表示),其余的是空地(用'.'表示).每时每刻,地面都会向某个方向倾斜 ...

  10. luogu P2254 [NOI2005]瑰丽华尔兹

    题目链接 luogu P2254 [NOI2005]瑰丽华尔兹 题解 为什么我我我不放放放bzoj的链接呢? 因为打的暴力啊,然后bzojT了呀QAQQQQQ(逃 然后luogu竟然过了呀呀呀 dp[ ...

随机推荐

  1. animate对颜色设置不起作用

    今天了解了一下stop的使用方法,但是实例中加入color:red的时候,动画效果没有实现,具体实例如下: http://jsbin.com/fezaroyene/edit?html,js,outpu ...

  2. 一个ERP项目实施工程师的若干体会

    本人在多年的工作中,参与了ERP的研发和实施,对ERP有较深的认识.在这里,根据自已的实施过程中的一些经历,把自已在实践中的一些体会贡献出来和大家共享,由于时间和精力所限,内容难免有不当之处,挂一漏万 ...

  3. Google Map API Version3 :代码添加和删除marker标记

    转自:http://blog.sina.com.cn/s/blog_4cdc44df0100u80h.html Google Map API Version3 教程:在地图 通过代添加和删除mark标 ...

  4. C#利用System.Net发送邮件(带 抄送、密送、附件、html格式的邮件)

    net2.0后,C#可以利用System.Net发送邮件了. 代码整理如下: 3. 增加IProcessMessage类,定义了一个消息方法,用于消息传递 /********************* ...

  5. sublime text3好用的插件

    1.安装package control sublime text3 的安装方法,ctrl+`,调出控制台输入 import urllib.request,os; pf = 'Package Contr ...

  6. [Head First设计模式]策略模式

    系列文章 [Head First设计模式]山西面馆中的设计模式——装饰者模式 [Head First设计模式]山西面馆中的设计模式——观察者模式 [Head First设计模式]山西面馆中的设计模式— ...

  7. 【Go入门教程4】struct类型(struct的匿名字段)

    struct Go语言中,也和C或者其他语言一样,我们可以声明新的类型,作为其它类型的属性或字段的容器.例如,我们可以创建一个自定义类型person代表一个人的实体.这个实体拥有属性:姓名和年龄.这样 ...

  8. Java 23种设计模式 (通俗易懂解释收集整理)

    (补充中...) P02 抽象工程模式 P14 TemplateMethod 模板方法模式 讲清楚了为什么叫做模板方法  http://www.cnblogs.com/java-my-life/arc ...

  9. git 教程(13)--创建与合并分支

    在版本回退里,你已经知道,每次提交,Git都把它们串成一条时间线,这条时间线就是一个分支.截止到目前,只有一条时间线,在Git里,这个分支叫主分支,即master分支.HEAD严格来说不是指向提交,而 ...

  10. ubuntu下MySQL中文乱码(新版本Mysql修改方法)

    前几天在开发的时候出现了中文查询阿里云服务器上的mysql的时候,查询出来的值为空,找了好久终于发现原因是ubuntu下的mysql无法识别中文,这就涉及到要调整编码格式啦!!!! 然后就在网上查了许 ...