HOJ 2133&POJ 2964 Tourist(动态规划)
Tourist
Time Limit: 1000MS Memory Limit: 65536K
Total Submissions: 1503 Accepted: 617
Description
A lazy tourist wants to visit as many interesting locations in a city as possible without going one step further than necessary. Starting from his hotel, located in the north-west corner of city, he intends to take a walk to the south-east corner of the city and then walk back. When walking to the south-east corner, he will only walk east or south, and when walking back to the north-west corner, he will only walk north or west. After studying the city map he realizes that the task is not so simple because some areas are blocked. Therefore he has kindly asked you to write a program to solve his problem.
Given the city map (a 2D grid) where the interesting locations and blocked areas are marked, determine the maximum number of interesting locations he can visit. Locations visited twice are only counted once.
Input
The first line in the input contains the number of test cases (at most 20). Then follow the cases. Each case starts with a line containing two integers, W and H (2 ≤ W, H ≤ 100), the width and the height of the city map. Then follow H lines, each containing a string with W characters with the following meaning:
‘.’ Walkable area
‘*’ Interesting location (also walkable area)
‘#’ Blocked area
You may assume that the upper-left corner (start and end point) and lower-right corner (turning point) are walkable, and that a walkable path of length H + W - 2 exists between them.
Output
For each test case, output a line containing a single integer: the maximum number of interesting locations the lazy tourist can visit.
Sample Input
2
9 7
*……..
…..**#.
..*…#
..####*#.
..#.*#.
…#**…
*……..
5 5
...
*###.
..*
.###*
...
Sample Output
7
8
经常写这种在一个矩阵里从左上角走到右下角,只能向下和向右走,这种是一个水DP。这道题目就是这类题目的升级类型。就是走到右下角还要返回左上角,以前走过的景点返回时走过都不算。我一开始天真的以为先求左上角到右下角的DP,再把图变一下,求右下角到左上角的DP,这样第二个样例就过不了。所以就要换一种方式,去的和来的不能分开DP,只能将他们和在一起才能得到正确的解。看了题解,状态是DP[i][j][k],表示到第i条斜线,去的路的横坐标是j,来的路的横坐标是k。还有的解法是i是第几步。
可以看出,如果一道题目的解法是动态规划,那么一定有其相应的状态转移方程,不能局限于题目的给的条件,
#include <iostream>
#include <string.h>
#include <stdlib.h>
#include <algorithm>
#include <math.h>
using namespace std;
int dp[205][105][105];
int n,m;
int t;
char a[105][105];
int main()
{
scanf("%d",&t);
while(t--)
{
scanf("%d%d",&m,&n);
for(int i=0;i<n;i++)
scanf("%s",a[i]);
memset(dp,0,sizeof(dp));
for(int i=1;i<=m+n-1;i++)
{
for(int j=0;j<n;j++)
{
for(int k=0;k<n;k++)
{
int y1=(i-1)-j;
if(y1<0)
continue;
if(y1>=m)
continue;
int y2=(i-1)-k;
if(y2<0)
continue;
if(y2>=m)
continue;
if(a[j][y1]=='#'||a[k][y2]=='#')
{dp[i][j][k]=0;continue;}
int ans=-2;
if(j-1>=0)
ans=max(ans,dp[i-1][j-1][k]);
if(k-1>=0)
ans=max(ans,dp[i-1][j][k-1]);
if(k-1>=0&&j-1>=0)
ans=max(ans,dp[i-1][j-1][k-1]);
ans=max(ans,dp[i-1][j][k]);
if(ans==-1)
{dp[i][j][k]=-1;continue;}
else
dp[i][j][k]=ans;
if(a[j][y1]=='*'&&y1!=y2)
dp[i][j][k]++;
if(a[k][y2]=='*'&&y1!=y2)
dp[i][j][k]++;
if(a[k][y2]=='*'&&a[j][y1]=='*'&&y1==y2)
dp[i][j][k]++;
}
}
}
printf("%d\n",dp[m+n-1][n-1][n-1]);
}
return 0;
}
HOJ 2133&POJ 2964 Tourist(动态规划)的更多相关文章
- HOJ 2124 &POJ 2663Tri Tiling(动态规划)
Tri Tiling Time Limit: 1000MS Memory Limit: 65536K Total Submissions: 9016 Accepted: 4684 Descriptio ...
- poj 3783 Balls 动态规划 100层楼投鸡蛋问题
作者:jostree 转载请注明出处 http://www.cnblogs.com/jostree/p/4098409.html 题目链接:poj 3783 Balls 动态规划 100层楼投鸡蛋问题 ...
- HOJ 2148&POJ 2680(DP递推,加大数运算)
Computer Transformation Time Limit: 1000MS Memory Limit: 65536K Total Submissions: 4561 Accepted: 17 ...
- poj 2229 一道动态规划思维题
http://poj.org/problem?id=2229 先把题目连接发上.题目的意思就是: 把n拆分为2的幂相加的形式,问有多少种拆分方法. 看了大佬的完全背包代码很久都没懂,就照着网上的写了动 ...
- [POJ 2063] Investment (动态规划)
题目链接:http://poj.org/problem?id=2063 题意:银行每年提供d种债券,每种债券需要付出p[i]块钱,然后一年的收入是v[i],到期后我们把本金+收入取出来作为下一年度本金 ...
- [POJ 2923] Relocation (动态规划 状态压缩)
题目链接:http://poj.org/problem?id=2923 题目的大概意思是,有两辆车a和b,a车的最大承重为A,b车的最大承重为B.有n个家具需要从一个地方搬运到另一个地方,两辆车同时开 ...
- POJ 1088 滑雪 -- 动态规划
题目地址:http://poj.org/problem?id=1088 Description Michael喜欢滑雪百这并不奇怪, 因为滑雪的确很刺激.可是为了获得速度,滑的区域必须向下倾斜,而且当 ...
- poj 1159 Palindrome - 动态规划
A palindrome is a symmetrical string, that is, a string read identically from left to right as well ...
- poj 2385【动态规划】
poj 2385 Apple Catching Time Limit: 1000MS Memory Limit: 65536K Total Submissions: 14007 Accepte ...
随机推荐
- 关于redis连接池
1.redis-py不需要显式使用连接池. 在幕后,redispy使用一个连接池来管理与Redis服务器的连接.默认情况下,每个Redis实例将依次创建自己的连接池.您可以通过将已创建的连接池实例传递 ...
- vs2012修复问题
多装了一个.net framework4.5.1结果vs不能拥,借用了下面这个工具将vs2012从注册表中删除了 就能重装了 http://www.auslogics.com/en/software/ ...
- sublime + emmet(Zen Coding)
今天接触sublime这个编辑器,一下子就喜欢上它了,以前我一直使用NOTEPAD++,果断换上sublime玩玩,呵呵 编辑功能啥的没话,作为前端开发的话,和emmet(原名叫Zen Coding) ...
- 入门常用SQL及官方文档的使用
SQL语句基础理论 SQL是操作和检索关系型数据库的标准语言,标准SQL语句可用于操作关系型数据库. 5大主要类型: ①DQL(Data Query Language,数据查询语言)语句,主要由于se ...
- 【代码审计】iCMS_v7.0.7 search.admincp.php页面存在SQL注入漏洞
0x00 环境准备 iCMS官网:https://www.icmsdev.com 网站源码版本:iCMS-v7.0.7 程序源码下载:https://www.icmsdev.com/downloa ...
- /var/spool/postfix/maildrop/ 中有大量的文件
今天查看硬盘剩余的容量,发现‘/’目录下占用了大量的空间:可我在这个目录下面没有放什么东西:仔细查看在/var/spool/postfix/maildrop/ 中发现了大量的文件.怎么会有这么多的文件 ...
- SaltStack 使用 Jinja2 模板
Jinja2 是基于 python 的一个模板引擎,如下,使用 Jinja2 实现根据不同的操作系统分发不同的文件: [root@localhost ~]$ cat /srv/salt/test.sl ...
- 解决16bit压缩贴图失真问题
选择索引模式
- Kafka manager安装 (支持0.10以后版本consumer)
下载地址: https://pan.baidu.com/s/1jIE3YL4 步骤: 1. 解压kafka-manager-1.3.2.1.zip 2. cd kafka-manager-1.3.2 ...
- WebForm的初步认识
嘿嘿,这里就简单的总结一下初步学习webform以及对他的认识,其实大家都认为webform很讨厌,因为好多都是给我们封装好的,而且现在好多的公司已经慢慢的从中逃离出来选择使用mvc架构,甚至好多的项 ...