博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
2017 Hackatari Codeathon C. Arcade(DP)(滚动数组)
阅读量:6104 次
发布时间:2019-06-20

本文共 2940 字,大约阅读时间需要 9 分钟。

C. Arcade
time limit per test
1 second
memory limit per test
256 megabytes
input
standard input
output
standard output

Abdullah and Haritha were building a 3D printed arcade machine. Abdullah had worked on the hardware, while Haritha had been working on the game that will be running on the arcade machine.

The game is represented as a 2D grid of R rows and C columns. The goal of the game is to build the maximum possible number of Hackatari logos. Hackatari's logo consists of 5 symbols, they are: {

x, o,  > ,  - , | }. When the game starts, the player will have an infinite number of the first two symbols {
x,  and o}.

Each cell of the grid contains one of the three-to-last symbols of the logo, specifically, { > ,  - ,  or | }.

The player is placed at the top-left cell, and is only allowed to move to the cell below him, or to the one to his right. The player is not allowed to go outside the grid. To collect a symbol from a cell, the player needs to move to that cell. The goal of the game is to build the maximum number of Hackatari logos using the collected symbols.

Abdullah was testing Haritha’s game, recently, and he got a score of 103%, which means that the maximum score that Haritha expected, was less than the maximum score that the player can actually achieve.

Can you help Haritha fix his game by writing a program that finds the maximum number of logos that can actually be built??

Input

The first line of input contains two integers, R and C (1 ≤ R, C ≤ 100), the number of rows and the number of columns in the grid, respectively.

Each of the following R lines contains C characters, each character belongs to the set: { > ,  - , | }.

Output

On a single line, print the maximum number of Hackatari logos.

Examples
Input
3 4 >|>- -|-> ->-|
Output
2
Input
4 2 >- >- >- ||
Output
1 【分析】给你一个图,开始在左上角,需要走向右下角 ,每次只能向下或者向右,问经过的这三种符号数量最小的是多少 。  dp[i][j][x][y]表示走到i,j这个位置经过>,|分别为x,y次这种情况是否存在。这个数组是100*100*200*200的,发现爆内存。。。  然后就有滚动数组这个东西了,因为当扫到第i行时,只有上一行有用,那么就可以将之前的删了,所以就可以开3*100*200*200的。
#include 
#include
#include
#include
#include
#include
#include
#include
#include
#include
#define inf 0x3f3f3f3f#define met(a,b) memset(a,b,sizeof a)#define pb push_back#define mp make_pairtypedef long long ll;using namespace std;const int N = 1e2+10;const int M = 1e6+10;int n,m,k,tot=0,q;bool dp[3][N][2*N][2*N];char str[N][N];int main(){ scanf("%d%d",&n,&m); for(int i=1;i<=n;i++){ scanf("%s",str[i]+1); } dp[0][1][0][0]=true; for(int i=1;i<=n;i++){ met(dp[(i+1)%3],0); for(int j=1;j<=m;j++){ for(int x=0;x<=i+j-1;x++){ for(int y=0;x+y<=i+j-1;y++){ if(dp[(i+2)%3][j][x][y]||dp[i%3][j-1][x][y]){ if(str[i][j]=='>')dp[i%3][j][x+1][y]=true; if(str[i][j]=='|')dp[i%3][j][x][y+1]=true; if(str[i][j]=='-')dp[i%3][j][x][y]=true; } } } } } int ans=0; for(int i=0;i

 

转载于:https://www.cnblogs.com/jianrenfang/p/6665967.html

你可能感兴趣的文章
配置spring上下文
查看>>
Python异步IO --- 轻松管理10k+并发连接
查看>>
mysql-python模块编译问题解决
查看>>
java 中getDeclaredFields() 与getFields() 的区别
查看>>
熟练掌握doc命令下的文件操作
查看>>
Oracle中drop user和drop user cascade的区别
查看>>
【Linux】linux经常使用基本命令
查看>>
Java 内存区域和GC机制
查看>>
更新代码和工具,组织起来,提供所有博文(C++,2014.09)
查看>>
HTML模块化:使用HTML5 Boilerplate模板
查看>>
登记申请汇总
查看>>
Google最新截屏案例详解
查看>>
2015第31周一
查看>>
2015第31周日
查看>>
在使用EF开发时候,遇到 using 语句中使用的类型必须可隐式转换为“System.IDisposable“ 这个问题。...
查看>>
PHP使用DES进行加密和解密
查看>>
Oracle 如何提交手册Cluster Table事务
查看>>
BeagleBone Black第八课板:建立Eclipse编程环境
查看>>
在服务器上用Fiddler抓取HTTPS流量
查看>>
文件类似的推理 -- 超级本征值(super feature)
查看>>