1171. Lost in Space
http://acm.timus.ru/problem.aspx?space=1&num=1171
一天的时间,WA了N遍,居然是因为数组开小了呀,我勒个去!鄙视自己。。。。。。
我是从第 1 层往上更新的
dp[level][x][y][day] 表示到第level层的(x,y)位置(第level层已经用完,该去第level+1层)且用了 day 天时的最多食物量
d[level][x][y][x1][y1][day] 表示在第level层 从(x,y)到(x1,y1) 且用day天 最多获取事物量
d[level][x][y][x1][y1][day]的求取过程可以爆搜
dp[level][x][y][day]=max(dp[level][x][y][day] , dp[level-1][x1][y1][day1]+d1[level][x][y][x1][y1][day-day1])
代码:
#include<iostream>
#include<cstdio>
#include<string>
#include<cstring>
#include<vector> using namespace std; const double eps=1e-9;
const int INF=0x3f3f3f3f;
const int N=17;
int dp[N][4][4][16*N];
int fx[N][4][4][16*N],fy[N][4][4][16*N],fd[N][4][4][16*N];
int d1[N][4][4][4][4][N];
int d[N][4][4][4][4][N];
int food[N][4][4];
int down[N][4][4];
int X[]={0,1,0,-1};
int Y[]={1,0,-1,0};
char dir[]={'E','S','W','N'};
bool visited[4][4];
int level,sx,sy;
void dfs(int x,int y,int f,int ln,int path)
{
visited[x][y]=true;
f+=food[level][x][y];
++ln;
if(d1[level][sx][sy][x][y][ln]<f)
{
d1[level][sx][sy][x][y][ln]=f;
d[level][sx][sy][x][y][ln]=path;
}
for(int i=0;i<4;++i)
{
int x1=x+X[i];
int y1=y+Y[i];
if(x1>=0&&x1<4&&y1>=0&&y1<4&&!visited[x1][y1])
{
int path1=(path|(i<<(2*(ln-1))));
dfs(x1,y1,f,ln,path1);
}
}
visited[x][y]=false; }
int main()
{
//freopen("data.in","r",stdin);
int n,ex,ey;
scanf("%d",&n);
int days=n*16;
for(int i=n;i>=1;--i)
{
for(int x=0;x<4;++x)
for(int y=0;y<4;++y)
scanf("%d",&food[i][x][y]);
for(int x=0;x<4;++x)
for(int y=0;y<4;++y)
scanf("%d",&down[i][x][y]);
}
scanf("%d %d",&ex,&ey);--ex;--ey;
for(int i=1;i<=n;++i)
for(int x=0;x<4;++x)
for(int y=0;y<4;++y)
{
for(int x1=0;x1<4;++x1)
for(int y1=0;y1<4;++y1)
for(int l=0;l<=days;++l)
d1[i][x][y][x1][y1][l]=-1;
memset(visited,false,sizeof(visited));
level=i;sx=x;sy=y;
dfs(x,y,0,0,0);
} memset(dp,-1,sizeof(dp)); for(int x=0;x<4;++x)
for(int y=0;y<4;++y)
dp[0][x][y][0]=0; for(int i=0;i<n;++i)
for(int x=0;x<4;++x)
for(int y=0;y<4;++y)
for(int l=0;l<=days;++l)
if(dp[i][x][y][l]>=0&&(down[i+1][x][y]||i==0))
{
for(int x1=0;x1<4;++x1)
for(int y1=0;y1<4;++y1)
for(int r=1;r<=16;++r)
if(d1[i+1][x1][y1][x][y][r]!=-1)
{
if(dp[i+1][x1][y1][l+r]<dp[i][x][y][l]+d1[i+1][x1][y1][x][y][r])
{
add[i+1][x1][y1][l+r]=r;
fx[i+1][x1][y1][l+r]=x;
fy[i+1][x1][y1][l+r]=y;
fd[i+1][x1][y1][l+r]=l;
}
}
}
int k=1;
for(int l=1;l<=days;++l)
if(dp[n][ex][ey][l]*k>dp[n][ex][ey][k]*l)
k=l;
printf("%.4f\n",1.0*dp[n][ex][ey][k]/k);
vector<char>ans;
int deep=n;
while(deep>0)
{
int x1=fx[deep][ex][ey][k],y1=fy[deep][ex][ey][k],k1=fd[deep][ex][ey][k];
int path=d[deep][ex][ey][x1][y1][k-k1];
for(int i=1;i<k-k1;++i)
{
ans.push_back(dir[path&0x3]);
path=path>>2;
}
ex=x1;ey=y1;k=k1; if(deep>1)
{ans.push_back('D');}
--deep;
}
printf("%d\n",ans.size());
for(unsigned int i=0;i<ans.size();++i)
printf("%c",ans[i]);
if(ans.size()>0)
printf("\n"); return 0;
}
1171. Lost in Space的更多相关文章
- java head space/ java.lang.OutOfMemoryError: Java heap space内存溢出
上一篇JMX/JConsole调试本地还可以在centos6.5 服务器上进行监控有个问题端口只开放22那么设置的9998端口 你怎么都连不上怎么监控?(如果大神知道还望指点,个人见解) 线上项目出现 ...
- Eclipse中启动tomcat报错java.lang.OutOfMemoryError: PermGen space的解决方法
有的项目引用了太多的jar包,或者反射生成了太多的类,异或有太多的常量池,就有可能会报java.lang.OutOfMemoryError: PermGen space的错误, 我们知道可以通过jvm ...
- myeclipse 内存不够用报错PermGen space 和 An internal error has occurred.
最近项目中又增加了新的模块,项目的代码又多了不少.运行的时候总是报如下错误 Exception in thread "http-apr-80-exec-6" java.lang.O ...
- java.lang.OutOfMemoryError: PermGen space及其解决方法
PermGen space的全称是Permanent Generation space,是指内存的永久保存区域OutOfMemoryError: PermGen space从表面上看就是内存益出,解决 ...
- User space 与 Kernel space
学习 Linux 时,经常可以看到两个词:User space(用户空间)和 Kernel space(内核空间). 简单说,Kernel space 是 Linux 内核的运行空间,User spa ...
- java.lang.OutOfMemoryError: PermGen space错误解决方法
1. MyEclipse 中报 PermGen space window--> preferences-->Myclipse-->Servers-->Tomcat- ...
- Git使用出错:Couldn‘t reserve space for cygwin‘s heap, Win32
今天使用Git在命令行下更新代码遇到了问题,起初觉得是自己安装某软件导致冲突,从网上搜索了一下找到类似问题,成功解决问题. 错误信息如下: E:\storm-sql>git pull origi ...
- 修改windows自带的Ctrl+Space输入法切换快捷键
使用场景: 多为我等码农使用一些编辑器时,编辑器的默认代码提示热键为 ctrl+space ,但这个热键被系统的输入法开关占用.如果遇到可以设置快捷键的编辑器还好,要是不能设置的话(比如火狐浏览器的代 ...
- Disk Space Usage 术语理解:unallocated, unused and reserved
通过standard reports查看Disk Usage,选中Database,右击,选择Reports->Standard Reports->Disk Space Usage,截图如 ...
随机推荐
- Hibernate(开放源代码的对象关系映射框架)
Hibernate是一个开放源代码的对象关系映射框架,它对JDBC进行了非常轻量级的对象封装,它将POJO与数据库表建立映射关系,是一个全自动的orm框架,hibernate可以自动生成SQL语句,自 ...
- 如何使用JDBC实现数据访问对象层(DAO)
JAVA是面向对象的语言,开发者在操作数据的时候,通常更习惯面对一个特定类型的对象,如一个用户就是一个User类的对象.DAO层需要做的,就是为上层提供充分的对象支持,让上层再也看不到具体的数据,而是 ...
- [iOS][issis] requestLocationWithReGeocode AMapLocationErrorDomain Code=5 "取消"
Tip: IOS 使用高德地图一次定位 (在该博客找到了解决答案) 在定位时如果出现下面这个Error,说明你的locationManager没有设置成全局变量,导致locationManager提 ...
- [转载]自己编写 php 在线问卷调查程序
<html> <head> <title>问卷调查</title> <meta http-equiv="Content-Type ...
- localhost访问错误Forbidden You don't have permission to access / on this server.解决办法(亲测)
在httpd.conf文件下找到这段: <Directory /> Options FollowSymLinks AllowOverride None Order deny,allow D ...
- [地图SkyLine二次开发]框架(4)
继续上一节... 1.Extjs5.0版Menu. -将Extjs包引入MenuPage.html页. 2.前段用Extjs的MVC框架 -在根目录下创建app文件夹,文件夹下分别创建controll ...
- 启动windows bat文件出现错误,直接关闭
如果执行运行run.bat,提示错误直接退出后,可以直接使用cmd命令进入当前目录,运行,会显示错误信息.
- 微软亚洲实验室一篇超过人类识别率的论文:Delving Deep into Rectifiers: Surpassing Human-Level Performance on ImageNet Classification ImageNet Classification
在该文章的两大创新点:一个是PReLU,一个是权值初始化的方法.下面我们分别一一来看. PReLU(paramter ReLU) 所谓的PRelu,即在 ReLU激活函数的基础上加入了一个参数,看一个 ...
- MFC编程入门之十九(对话框:颜色对话框)
在上一节中为大家讲解了字体对话框的使用方法,熟悉了字体对话框,本节继续讲另一种通用对话框--颜色对话框. 颜色对话框大家肯定也不陌生,我们可以打开它选择需要的颜色,简单说,它的作用是用来选择颜色.MF ...
- Android 之surfaceView (画动态圆圈)
通过之前介绍的如何自定义View, 我们知道使用它可以做一些简单的动画效果.它通过不断循环的执行View.onDraw方法,每次执行都对内部显示的图形做一些调整,我们假设 onDraw方法每秒执行 ...