邱老师降临小行星

Time Limit: 20 Sec  Memory Limit: 256 MB

题目连接

http://acm.uestc.edu.cn/#/contest/show/61

Description

人赢邱老师和任何男生比,都是不虚的。有一天,邱老师带妹子(们)来到了一个N行M列平面的小行星。对于每一个着陆地点,邱老师总喜欢带着妹子这样走:假设着陆地点为(r0, c0),那么他们下一步只能选择相邻格点,向四周走,即(r0–1, c0), (r0 + 1, c0), (r0, c0–1)或(r0, c0 + 1)。之后的路程必须严格按照右转-前进-左转-前进-右转......的道路前行。但是由于邱老师很心疼妹子,所以崎岖的山脉不可以到达。当不能前进时必须要原路返回。如下图。

问,邱老师在哪里着陆可以游历这颗星球最多的土地,输出可能访问到的最多的格点数。

Input

第一行一个整数T, 0<T≤20,表示输入数据的组数。 对于每组数据,第一行有两个整数N和M,分别表示行数和列数,0<N,M≤1000 下面N行,每行M个字符(0或1)。 1代表可到达的地方,0代表山脉(不可到达的地方)。

Output

对于每一组数据,输出一个整数后换行,表示选择某点着陆后,可能访问到的最多的格点数。

Sample Input

2
4 3
111
111
111
111
3 3
111
101
111

Sample Output

10
4

HINT

题意

题解:

记忆化搜索,存一下值就好了

代码:

//qscqesze
#include <cstdio>
#include <cmath>
#include <cstring>
#include <ctime>
#include <iostream>
#include <algorithm>
#include <set>
#include <vector>
#include <sstream>
#include <queue>
#include <typeinfo>
#include <fstream>
#include <map>
#include <stack>
typedef long long ll;
using namespace std;
//freopen("D.in","r",stdin);
//freopen("D.out","w",stdout);
#define sspeed ios_base::sync_with_stdio(0);cin.tie(0)
#define maxn 200001
#define mod 10007
#define eps 1e-9
int Num;
char CH[];
//const int inf=0x7fffffff; //нчоч╢С
const int inf=0x3f3f3f3f;
/* inline void P(int x)
{
Num=0;if(!x){putchar('0');puts("");return;}
while(x>0)CH[++Num]=x%10,x/=10;
while(Num)putchar(CH[Num--]+48);
puts("");
}
*/
//**************************************************************************************
inline ll read()
{
int x=,f=;char ch=getchar();
while(ch<''||ch>''){if(ch=='-')f=-;ch=getchar();}
while(ch>=''&&ch<=''){x=x*+ch-'';ch=getchar();}
return x*f;
}
inline void P(int x)
{
Num=;if(!x){putchar('');puts("");return;}
while(x>)CH[++Num]=x%,x/=;
while(Num)putchar(CH[Num--]+);
puts("");
} char s[][];
int dp[][][];
int dx[]={-,,,,,,,-};
int dy[]={,,,,,-,-,};
int n,m;
void dfs(int i,int j,int k)
{
if(k%==)
{
if(i+dx[k]<||i+dx[k]>=n||j+dy[k]<||j+dy[k]>=m)
dp[i][j][k]=;
else if(s[i+dx[k]][j+dy[k]]=='')
dp[i][j][k]=;
else
{
if(dp[i+dx[k]][j+dy[k]][k+]==-)
dfs(i+dx[k],j+dy[k],k+);
dp[i][j][k]=;
dp[i][j][k]+=dp[i+dx[k]][j+dy[k]][k+];
}
}
else
{
if(i+dx[k]<||i+dx[k]>=n||j+dy[k]<||j+dy[k]>=m)
dp[i][j][k]=;
else if(s[i+dx[k]][j+dy[k]]=='')
dp[i][j][k]=;
else
{
if(dp[i+dx[k]][j+dy[k]][k-]==-)
dfs(i+dx[k],j+dy[k],k-);
dp[i][j][k]=;
dp[i][j][k]+=dp[i+dx[k]][j+dy[k]][k-];
}
}
}
int main()
{
int t=read();
for(int cas=;cas<=t;cas++)
{
n=read(),m=read();
for(int i=;i<n;i++)
for(int j=;j<m;j++)
for(int k=;k<;k++)
dp[i][j][k]=-;
for(int i=;i<n;i++)
scanf("%s",s[i]);
int ans2=;
for(int i=;i<n;i++)
{
for(int j=;j<m;j++)
{
if(s[i][j]=='')
continue;
int ans=;
if(dp[i][j][]==-)
dfs(i,j,);
ans+=dp[i][j][];
if(dp[i][j][]==-)
dfs(i,j,);
ans+=dp[i][j][];
if(dp[i][j][]==-)
dfs(i,j,);
ans+=dp[i][j][];
if(dp[i][j][]==-)
dfs(i,j,);
ans+=dp[i][j][];
ans2=max(ans2,ans);
}
}
printf("%d\n",ans2);
}
}

最新文章

  1. Windows Server配置Jenkins,实现监测SVN提交自动构建.net4.5的项目
  2. CSS样式-文字超出宽部分用省略号代替
  3. MySQL 第一篇
  4. C迷途指针
  5. bzoj3555 企鹅QQ
  6. HTML 5 应用程序缓存
  7. [原创]java WEB学习笔记67:Struts2 学习之路-- 类型转换概述, 类型转换错误修改,如何自定义类型转换器
  8. JAVA构造器、this、super
  9. DGV属性
  10. cf C. Bits
  11. Spark学习笔记--概念知识
  12. 【转】ubuntu安装ftp服务器
  13. python--DenyHttp项目(2)--ACM监考客户端1.0版
  14. EduSoho程序上线实录
  15. chorme调试Paused in debugger问题解决
  16. saiku运行时报错max_length_for_sort_data 需要set higher
  17. win8.1 AMD 屏幕亮度无法调整
  18. MySQL字符集详解
  19. LOJ 3057 「HNOI2019」校园旅行——BFS+图等价转化
  20. JMeter&#160;JMeter自身运行性能优化

热门文章

  1. OSCP考试回顾
  2. dlmalloc(一)【转】
  3. 在Perl中使用Getopt::Long模块来接收用户命令行参数
  4. 中高级JAVA面试知识点(个人整理)
  5. c++输出保留固定小数位数
  6. CGIC函数说明
  7. system()函数
  8. python 分词库jieba
  9. 16.Spark Streaming源码解读之数据清理机制解析
  10. Web开发——服务器端应用技术简单比较