Game in Momotetsu World

题目大意

在一个 \(n\times m\) 的网格中,存在红色和蓝色两种格子,红色格子用 - 表示,蓝色格子用 + 表示。

现在 Takahashi 和 Aoki 要在这个网格中进行游戏,游戏的规则如下:

  • 初始时,有一枚棋子摆放在左上角,即 \((1,1)\) 的位置。两名玩家的分数均为 \(0\)。
  • 双方轮流行动,Takahashi 先行动。
  • 在每次行动中,行动者可以选择将棋子向下或向右移动一格,但移动后不能超出网格。移动后如果棋子位于红色格子,那么行动者的分数 \(-1\),否则 \(+1\)。
  • 当棋子无法行动时,即位于 \((n,m)\) 时,游戏结束,得分高者为胜者。

现在告诉你网格的颜色情况,请你判断谁将会获胜。你可以认为这两名玩家都绝顶聪明。

思路分析

在打 AT 时,一个重要的原则是遇事不决就 DP。

考虑 DP,设 \(f_{i,j}\) 表示棋子位于 \((i,j)\) 时,Takahashi 的得分与 Aoki 的得分的差。

那么 Takahashi 的目标是最大化这个值,而 Aoki 则想要最小化这个值。

因为棋子只能向右或向下走,所以此时的回合数就是 \(i+j-1\)(回合从 \(1\) 开始)。那么容易写出状态转移方程:

\[f_{i,j}=\begin{cases}\max(f_{i+1,j}+a_{i+1,j},f_{i,j+1}+a_{i,j+1})&i+j-1\equiv 1\pmod2\\\min(f_{i+1,j}-a_{i+1,j},f_{i,j+1}-a_{i,j+1})&i+j-1\equiv 0\pmod2\end{cases}
\]

(\(a_{i,j}\) 表示这一位的符号,即若 \((i,j)\) 为 +,那么 \(a_{i,j}\) 为 \(1\),否则为 \(-1\)。)

因为转移比较奇怪,所以考虑用记搜实现。

代码

#include <bits/stdc++.h>
using namespace std;
const int N=2020;
#define inf 0x3f3f3f3f int a[N][N],dp[N][N];
int n,m;
char ch[N]; int dfs(int x,int y){
if(x==n&&y==m) return 0;//到达边界
if(dp[x][y]) return dp[x][y];
if((x+y-1)%2==1){
dp[x][y]=-inf;//记得赋初值和特判边界!
if(x!=n) dp[x][y]=max(dp[x][y],dfs(x+1,y)+a[x+1][y]);
if(y!=m) dp[x][y]=max(dp[x][y],dfs(x,y+1)+a[x][y+1]);
return dp[x][y];
}
else{
dp[x][y]=inf;
if(x!=n) dp[x][y]=min(dp[x][y],dfs(x+1,y)-a[x+1][y]);
if(y!=m) dp[x][y]=min(dp[x][y],dfs(x,y+1)-a[x][y+1]);
return dp[x][y];
}
} int main(){
scanf("%d%d",&n,&m);
for(int i=1;i<=n;i++){
scanf("%s",ch+1);
for(int j=1;j<=m;j++)
a[i][j]=(ch[j]=='+')?1:-1;
}
int ans=dfs(1,1);//1 1 即为答案
if(ans>0) cout<<"Takahashi\n";
if(ans==0) cout<<"Draw\n";
if(ans<0) cout<<"Aoki\n";
return 0;
}

[ABC201D] Game in Momotetsu World 题解的更多相关文章

  1. 2016 华南师大ACM校赛 SCNUCPC 非官方题解

    我要举报本次校赛出题人的消极出题!!! 官方题解请戳:http://3.scnuacm2015.sinaapp.com/?p=89(其实就是一堆代码没有题解) A. 树链剖分数据结构板题 题目大意:我 ...

  2. noip2016十连测题解

    以下代码为了阅读方便,省去以下头文件: #include <iostream> #include <stdio.h> #include <math.h> #incl ...

  3. BZOJ-2561-最小生成树 题解(最小割)

    2561: 最小生成树(题解) Time Limit: 10 Sec  Memory Limit: 128 MBSubmit: 1628  Solved: 786 传送门:http://www.lyd ...

  4. Codeforces Round #353 (Div. 2) ABCDE 题解 python

    Problems     # Name     A Infinite Sequence standard input/output 1 s, 256 MB    x3509 B Restoring P ...

  5. 哈尔滨理工大学ACM全国邀请赛(网络同步赛)题解

    题目链接 提交连接:http://acm-software.hrbust.edu.cn/problemset.php?page=5 1470-1482 只做出来四道比较水的题目,还需要加强中等题的训练 ...

  6. 2016ACM青岛区域赛题解

    A.Relic Discovery_hdu5982 Time Limit: 2000/1000 MS (Java/Others)    Memory Limit: 65536/65536 K (Jav ...

  7. poj1399 hoj1037 Direct Visibility 题解 (宽搜)

    http://poj.org/problem?id=1399 http://acm.hit.edu.cn/hoj/problem/view?id=1037 题意: 在一个最多200*200的minec ...

  8. 网络流n题 题解

    学会了网络流,就经常闲的没事儿刷网络流--于是乎来一发题解. 1. COGS2093 花园的守护之神 题意:给定一个带权无向图,问至少删除多少条边才能使得s-t最短路的长度变长. 用Dijkstra或 ...

  9. CF100965C题解..

    求方程 \[ \begin{array}\\ \sum_{i=1}^n x_i & \equiv & a_1 \pmod{p} \\ \sum_{i=1}^n x_i^2 & ...

  10. JSOI2016R3 瞎BB题解

    题意请看absi大爷的blog http://absi2011.is-programmer.com/posts/200920.html http://absi2011.is-programmer.co ...

随机推荐

  1. 彻底解决各种浏览器访问不了GitHub问题(注意代理)

    如果有穿墙插件如Google助手  VPN  SS 之类别 有可能被全局代理 首先关闭这些软件 或者浏览器插件 假设,您的本地代理端口为:1080 ,打开git base窗口进行按下列的方式设置.(在 ...

  2. ERP导出(自定义格式表格)R报表开发代码

    按照正常流程新建程序,画面修改上传,程序下载修改 导入JAVA包,在global.import下 IMPORT com IMPORT JAVA java.net.URL IMPORT JAVA org ...

  3. Python 引用问题 - ImportError: attempted relative import with no known parent package

    问题描述 近日在尝试引用其他文件的代码时,遇到了错误: ImportError: attempted relative import with no known parent package. 问题大 ...

  4. RabbitMQ基本配置

    1.用户角色配置 自带的guest/guest 超级管理员五中不同角色配置: 普通管理者(management):仅可登陆管理控制台,无法看到节点信息,也无法对策略进行管理. 策略制定者(policy ...

  5. Win10激活步骤、密钥key

    统安装完毕后,首先以Win+R打开CMD命令行窗口,按下Win+X,选择命令提示符(管理员). Win10企业版 用户举例请依次输入: slmgr /ipk NPPR9-FWDCX-D2C8J-H87 ...

  6. 打包 IPA processing failed 失败

    查看报错日志:有些SDK含有x86_64架构,移除即可 1. cd 该库SDK路径下 2.执行 lipo -remove x86_64 BaiduTraceSDK -o BaiduTraceSDK 解 ...

  7. docker 安装redis 6.0.8哨兵集群(一主两从三哨兵)

    准备三台主机并且安装了docker 192.168.31.132 192.168.31.134 192.168.31.144 linux 版redis6.0.8 下载 下载地址:https://dow ...

  8. HTML前端js

    ajax请求方法书写 $.ajax({ type:"POST", url:CONTEXT_PATH+"/appAudit/insertSnDocCountAdmin&qu ...

  9. BUUCTF-MISC-面具下的flag(vmdk的解压和Brainfuck与Ook解密)

    准备工作 下载附件得到一个一张图片 丢入winhex,发现还有一个flag.vmdk文件 vmdk文件其实是虚拟机使用的硬盘文件 打开kali binwalk -e mianju.jpg 关键步骤 这 ...

  10. Burnside 定理

    Burnside 定理 问题: 给定一个 \(n\) 个点,\(n\) 条边的环,有 \(m\) 种颜色,给每个顶点染色,问有多少种本质不同的染色方案,答案对 \(10^9+7\) 取模 注意本题的本 ...