首页 技术 正文
技术 2022年11月23日
0 收藏 328 点赞 4,444 浏览 1358 个字

pro: 给出一个n*m的地图,刚开始人在(x,y),每次给出一段区间(l,r,t),表示在时间[l,r]内,可以使人向4个方向(t)移动一格,或者不动。求最大可以移动多少格。

sol: 考虑每一列(上下移)或者一行(左右移)的情况。以右移为例,我们可以很快列出dp方程:f[x][y][i]=max(f[x][y][i],f[x][j][i]+y-j)。这个dp方程我们可以用单调队列维护,所以复杂度就是nmk的。

#include<bits/stdc++.h>
#define rep(i,a,b) for(int i=a;i<=b;i++)
using namespace std;
const int maxn=;
const int inf=1e9+;
int dp[maxn][maxn][],ans;
char c[maxn][maxn];
int X[]={,-,,,},Y[]={,,,-,};
int q[maxn][],head,tail,N,M,now;
int update(int x,int y,int tp,int tk)
{
int res=dp[q[tp][]][q[tp][]][(tk^)&]+now-q[tp][];
dp[x][y][tk&]=max(dp[x][y][tk&],res);
return res;
}
int get(int tp,int tk)
{
int res=dp[q[tp][]][q[tp][]][(tk^)&]+now-q[tp][];
return res;
}
void work(int x,int y,int tK,int len,int opt)
{
head=,tail=; now=;
while(x>=&&x<=N&&y>=&&y<=M) {
dp[x][y][tK&]=dp[x][y][(tK^)&];
if(c[x][y]=='x') head=,tail=;
while(tail>=head&&now-q[head][]>len) head++;
while(tail>=head&&get(tail,tK)<dp[x][y][(tK^)&]) tail--;
if(tail>=head)
update(x,y,head,tK);
ans=max(ans,dp[x][y][tK&]);
tail++; q[tail][]=x; q[tail][]=y; q[tail][]=now++;
x+=X[opt]; y+=Y[opt];
}
}
int main()
{
int K,x,y,L,R,opt;
scanf("%d%d%d%d%d",&N,&M,&x,&y,&K);
rep(i,,N) scanf("%s",c[i]+);
rep(i,,N) rep(j,,M) rep(k,,K) dp[i][j][k]=-inf;
dp[x][y][]=;
rep(i,,K){
scanf("%d%d%d",&L,&R,&opt);
if(opt==) rep(j,,M) work(N,j,i,R-L+,opt);
if(opt==) rep(j,,M) work(,j,i,R-L+,opt);
if(opt==) rep(j,,N) work(j,M,i,R-L+,opt);
if(opt==) rep(j,,N) work(j,,i,R-L+,opt);
}
printf("%d\n",ans);
return ;
}
上一篇: myshell
下一篇: 决策树——ID3
相关推荐
python开发_常用的python模块及安装方法
adodb:我们领导推荐的数据库连接组件bsddb3:BerkeleyDB的连接组件Cheetah-1.0:我比较喜欢这个版本的cheeta…
日期:2022-11-24 点赞:878 阅读:9,291
Educational Codeforces Round 11 C. Hard Process 二分
C. Hard Process题目连接:http://www.codeforces.com/contest/660/problem/CDes…
日期:2022-11-24 点赞:807 阅读:5,718
下载Ubuntn 17.04 内核源代码
zengkefu@server1:/usr/src$ uname -aLinux server1 4.10.0-19-generic #21…
日期:2022-11-24 点赞:569 阅读:6,556
可用Active Desktop Calendar V7.86 注册码序列号
可用Active Desktop Calendar V7.86 注册码序列号Name: www.greendown.cn Code: &nb…
日期:2022-11-24 点赞:733 阅读:6,326
Android调用系统相机、自定义相机、处理大图片
Android调用系统相机和自定义相机实例本博文主要是介绍了android上使用相机进行拍照并显示的两种方式,并且由于涉及到要把拍到的照片显…
日期:2022-11-24 点赞:512 阅读:7,964
Struts的使用
一、Struts2的获取  Struts的官方网站为:http://struts.apache.org/  下载完Struts2的jar包,…
日期:2022-11-24 点赞:671 阅读:5,124