[ABC201D] 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\) 开始)。那么容易写出状态转移方程:
\]
(\(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 题解的更多相关文章
- 2016 华南师大ACM校赛 SCNUCPC 非官方题解
我要举报本次校赛出题人的消极出题!!! 官方题解请戳:http://3.scnuacm2015.sinaapp.com/?p=89(其实就是一堆代码没有题解) A. 树链剖分数据结构板题 题目大意:我 ...
- noip2016十连测题解
以下代码为了阅读方便,省去以下头文件: #include <iostream> #include <stdio.h> #include <math.h> #incl ...
- BZOJ-2561-最小生成树 题解(最小割)
2561: 最小生成树(题解) Time Limit: 10 Sec Memory Limit: 128 MBSubmit: 1628 Solved: 786 传送门:http://www.lyd ...
- Codeforces Round #353 (Div. 2) ABCDE 题解 python
Problems # Name A Infinite Sequence standard input/output 1 s, 256 MB x3509 B Restoring P ...
- 哈尔滨理工大学ACM全国邀请赛(网络同步赛)题解
题目链接 提交连接:http://acm-software.hrbust.edu.cn/problemset.php?page=5 1470-1482 只做出来四道比较水的题目,还需要加强中等题的训练 ...
- 2016ACM青岛区域赛题解
A.Relic Discovery_hdu5982 Time Limit: 2000/1000 MS (Java/Others) Memory Limit: 65536/65536 K (Jav ...
- poj1399 hoj1037 Direct Visibility 题解 (宽搜)
http://poj.org/problem?id=1399 http://acm.hit.edu.cn/hoj/problem/view?id=1037 题意: 在一个最多200*200的minec ...
- 网络流n题 题解
学会了网络流,就经常闲的没事儿刷网络流--于是乎来一发题解. 1. COGS2093 花园的守护之神 题意:给定一个带权无向图,问至少删除多少条边才能使得s-t最短路的长度变长. 用Dijkstra或 ...
- CF100965C题解..
求方程 \[ \begin{array}\\ \sum_{i=1}^n x_i & \equiv & a_1 \pmod{p} \\ \sum_{i=1}^n x_i^2 & ...
- JSOI2016R3 瞎BB题解
题意请看absi大爷的blog http://absi2011.is-programmer.com/posts/200920.html http://absi2011.is-programmer.co ...
随机推荐
- Docker安装及镜像加速器配置
Centos7安装 卸载旧版本(如果安装过旧版本的话) yum remove docker docker-common docker-selinux docker-engine 安装Docker依赖环 ...
- Spring的Bean标签配置(一)
Bean标签基本配置 由于配置对象交由Spring来创建 默认情况下它调用的的是类中的无参构造函数,如果没有无参构造函数则不会创建成功 id:唯一标识符号,反射是通过无参构造创建对象的. class: ...
- Linux 软件包:man pages
有时候,man ls 发现没有帮助文档,可以快递打开浏览器检索 "man ls" . # yum list | grep man | grep pages gl-manpages. ...
- HTML超文本标记语言3
三.HTML表单标签 1.form标签 <form> form标签 name=表单名称,action=表单提交的地址,method=表单提交方式:get/post get/post详解: ...
- K8S | Service服务发现
服务发现与负载均衡. 一.背景 在微服务架构中,这里以开发环境「Dev」为基础来描述,在K8S集群中通常会开放:路由网关.注册中心.配置中心等相关服务,可以被集群外部访问: 对于测试「Tes」环境或者 ...
- 跟运维学 Linux - 03
权限机制和性能指标 前面我们学完了操作文件和用户相关知识,本篇学习权限和性能相关知识. 文件的属性看起 看 linux 的权限,先从文件的属性看起 ls -l 加 -d 是只看这个文件夹: pjl@p ...
- 更专业省心的来了,你没必要研究UE4和Unity官方推流了!
在当今互联网时代,所有的内容制作者都希望尽可能触达到更多的目标受众,那就需要全平台发布内容并且可以轻松跨平台分享,包括手机.平板电脑.个人电脑以及交互式屏幕,用户能畅快的获得高质量的体验.需求催生了一 ...
- Vue+SpringBoot项目分离部署踩坑记录
昨天花了一晚上终于成功部署了个人网站,在这个过程中踩了很多坑,现在回顾总结记录一下,以免今后继续犯错误 前端:Vue 后端:SpringBoot 数据库:Mysql 一.前端 1.前端项目采用Ngin ...
- Linux 内核音频数据传递主要流程 (上)
Linux 用户空间应用程序通过声卡驱动程序(一般牵涉到多个设备驱动程序)和 Linux 内核 ALSA 框架导出的 PCM 设备文件,如 /dev/snd/pcmC0D0c 和 /dev/snd/p ...
- Web通用漏洞--sql注入
SQL注入 mysql注入目的:获取当前web权限 mysql注入--常规查询&union联合查询 MYSQL--Web组成架构 服务器搭建web服务可能存在多个站点搭建在一台服务器中,数据集 ...