Baker Vai LightOJ - 1071
题意:类似传纸条
方法:
把他要求的操作(一个人来回),转化为两个人同时走,除了开始和结束位置只能走不同路,得到的分数和的最大值即可。
一开始想到要定义的状态,是两个人的x(行)和y(列)坐标。这样时间和空间都为$O(n^4)$,都超出了,因此需要优化。注意到每个人从起点到终点的总步数一定是相同的,而且可以根据每个人走的步数和x坐标,推出这个人的y坐标。那么可以只记录步数和两个人的x坐标作为状态。这样就可以把时间/空间优化到$O(n^3)$。(空间还可以通过滚动数组再优化,但是不优化已经够用)
错误次数:2
原因:
1. 27行错误地写作ans[0][1][1]=1
2. ans第一维错误地与二、三维开了同样的大小(110),实际需要2倍的二、三维
3. 用了C++11的min({..,..})导致CE
#include<cstdio>
#include<cstring>
#include<algorithm>
using namespace std;
int T,TT,m,n,maxans;
int ans[][][];
int a[][];
int max(int a,int b,int c,int d)
{
int ans=a;
if(b>ans) ans=b;
if(c>ans) ans=c;
if(d>ans) ans=d;
return ans;
}
int main()
{
int i,j,j1,j2;
scanf("%d",&T);
for(TT=;TT<=T;TT++)
{
scanf("%d%d",&m,&n);
for(i=;i<=m;i++)
for(j=;j<=n;j++)
scanf("%d",&a[i][j]);
memset(ans,,sizeof(ans));
ans[][][]=a[][];//起点要特殊处理,两个人在同一位置
maxans=;
for(i=;i<=m+n-;i++)
for(j1=max(,i-n+);j1<=min(i+,m);j1++)//max和min是依据推导出的数据范围
for(j2=max(,i-n+);j2<=min(i+,m);j2++)
if(j1!=j2)//保证两个人不在同一行,也就是不在同一位置
ans[i][j1][j2]=max(ans[i-][j1][j2],ans[i-][j1-][j2],ans[i-][j1][j2-],ans[i-][j1-][j2-])+a[j1][i-j1+]+a[j2][i-j2+];
i=m+n-;//对于终点也要特殊处理,由于终点两个人可以到同一位置
for(j1=max(,i-n+);j1<=min(i+,m);j1++)
for(j2=max(,i-n+);j2<=min(i+,m);j2++)
ans[i][j1][j2]=max(ans[i-][j1][j2],ans[i-][j1-][j2],ans[i-][j1][j2-],ans[i-][j1-][j2-])+a[j1][i-j1+]+a[j2][i-j2+];
for(j1=;j1<=m;j1++)
for(j2=;j2<=m;j2++)
maxans=max(maxans,ans[m+n-][j1][j2]);
printf("Case %d: %d\n",TT,maxans-a[m][n]);
}
return ;
}
Baker Vai LightOJ - 1071的更多相关文章
- Baker Vai LightOJ - 1071 (MCMF)
在个给出的矩阵从,从左上角走到右下角,然后再从右下角走到左上角,两次不能经过想同的点,每个点都有一个价值,问最大的价值是多少. 可以把原来的问题化简成从左上角走两条路到右下角,然后把价值加起来,然是这 ...
- Lightoj 1071 - Baker Vai (双线程DP)
题目连接: http://lightoj.com/volume_showproblem.php?problem=1071 题目大意: 一个n*m的格子,Baker Vai要从(1,1)到(n,m)再回 ...
- LightOJ 1071 Baker Vai(拆点+最大费用流)题解
题意:给一个n*m的方格,每个格子上都有一个数字表示价值,小A在左上角,他从左上角走到右下角只能向右或向下走,然后再从右下角走上左上角,这次只能向上或向左走,这两条路绝对没有重复,问你怎样走有最大价值 ...
- 区间DP LightOJ 1422 Halloween Costumes
http://lightoj.com/volume_showproblem.php?problem=1422 做的第一道区间DP的题目,试水. 参考解题报告: http://www.cnblogs.c ...
- LightOj 1298 - One Theorem, One Year(DP + 欧拉)
题目链接:http://lightoj.com/volume_showproblem.php?problem=1298 题意:给你两个数 n, p,表示一个数是由前 k 个素数组成的,共有 n 个素数 ...
- 1214 - Large Division -- LightOj(大数取余)
http://lightoj.com/volume_showproblem.php?problem=1214 这就是一道简单的大数取余. 还想还用到了同余定理: 所谓的同余,顾名思义,就是许多的数被一 ...
- LightOJ Beginners Problems 部分题解
相关代码请戳 https://coding.net/u/tiny656/p/LightOJ/git 1006 Hex-a-bonacci. 用数组模拟记录结果,注意取模 1008 Fibsieve's ...
- LightOJ 1341 唯一分解定理
Aladdin and the Flying Carpet Time Limit:3000MS Memory Limit:32768KB 64bit IO Format:%lld &a ...
- lightoj 1370 欧拉函数
A - Bi-shoe and Phi-shoe Time Limit:2000MS Memory Limit:32768KB 64bit IO Format:%lld & % ...
随机推荐
- CentOS7虚拟机桥接设置及问题
转载请注明出处:jiq•钦's technical Blog 今天在VMWare WorkStation9中安装了CentOS7虚拟机. 虚拟机与宿主机网络连接有三种方式:桥接模式.NAT模式和Ho ...
- MFC 的 Picture Control 加载 BMP/PNG 图片的方法
1. 加载 BMP CStatic* pWnd = (CStatic*)GetDlgItem(IDC_PIC); // 得到 Picture Control 句柄 pWnd->ModifySty ...
- PowerDesigner逆向工程,从SQL Server数据库生成Physical Model
提前声明:这种方式貌似只能是Power Designer安装在数据库服务器的时候才可以,因为我按照成功的这个再去从本机逆向连接远程服务器的时候,一直提示:test failed......不讲了,尴尬 ...
- C++11 条件变量
C++11中的条件变量提供了用户等待的同步机制,在同步队列的应用中有很大的便利. 简单同步队列代码如下(SimpleSyncQueue.h): #ifndef SIMPLESYNCQUEUE_H #d ...
- 关于UISearchBar
iPhone开发之UISearchBar学习是本文要学习的内容,主要介绍了UISearchBar的使用,不多说,我们先来看详细内容.关于UISearchBar的一些问题. 1.修改UISearchBa ...
- bzoj3134: [Baltic2013]numbers
稍微用脑子想一想,要是一个回文数,要么s[i]==s[i+1]要么s[i]==s[i+2]就可以实锤了 所以多开两维表示最近两位选的是什么数就完了 注意前导0 #include<cstdio&g ...
- 666 专题五 AC自动机
Problem A.Keywords Search d.n个关键字,1段描述,求描述中出现了多少关键字 s. c. /* ac自动机模板 n个关键字,1段描述,求描述中出现了多少关键字 */ #inc ...
- classname.this 和 this的使用场景
今天在写代码时,发现在写了一个内部类,而在内部类中需要调用外部类的实例方法,直接使用this调用发现调用的不是外部类而是内部类,于是查找资料原来需要使用外部类的classname.this这样的调用, ...
- [angularJS]ng-hide|ng-show切换
<div class="row ng-scope"> <div class="col-lg-12"> <h1 class=&quo ...
- Docker 概念及基本用法
Docker 概念及基本用法 一. 本节内容简介 本实验中我们初步接触Docker的概念和基本用法.需要依次完成下面几项任务: 理解Docker是什么 学习如何在Linux上安装Docker 学习如何 ...