一双木棋(chess)

题目描述

菲菲和牛牛在一块 nn 行 mm 列的棋盘上下棋,菲菲执黑棋先手,牛牛执白棋后手。

棋局开始时,棋盘上没有任何棋子,两人轮流在格子上落子,直到填满棋盘时结束。落子的规则是:一个格子可以落子当且仅当这个格子内没有棋子且这个格子的左侧及上方的所有格子内都有棋子。

棋盘的每个格子上,都写有两个非负整数,从上到下第 ii 行中从左到右第 jj 列的格子上的两个整数记作 A_{i,j}Ai,j​、B_{i,j}Bi,j​。在游戏结束后,菲菲和牛牛会分别计算自己的得分:菲菲的得分是所有有黑棋的格子上的 A_{i,j}Ai,j​ 之和,牛牛的得分是所有有白棋的格子上的 B_{i,j}Bi,j​ 的和。

菲菲和牛牛都希望,自己的得分减去对方的得分得到的结果最大。现在他们想知道,在给定的棋盘上,如果双方都采用最优策略且知道对方会采用最优策略,那么,最终的结果如何。

输入格式

从标准输入中读入数据。

输入第一行包含两个正整数 n, mn,m,保证 n, m \leq 10n,m≤10。 接下来 nn 行,每行 mm 个非负整数,按从上到下从左到右的顺序描述每个格子上的第一个非负整数:其中第 ii 行中第 jj 个数表示 A_{i,j}Ai,j​。

接下来 nn 行,每行 mm 个非负整数,按从上到下从左到右的顺序描述每个格子上的第二个非负整数:其中第 ii 行中第 jj 个数表示 B_{i,j}Bi,j​。

输出格式

输出到标准输出中。

输出一个整数,表示菲菲的得分减去牛牛的得分的结果。

样例

样例输入

  1. 2 3
  2. 2 7 3
  3. 9 1 2
  4. 3 7 2
  5. 2 3 1

样例输出

  1. 2

样例解释

棋盘如图所示,双方都采用最优策略时,棋局如下:

  • 菲菲下在第 11 行第 11 列(这是第一步时唯一可以落子的格子);
  • 牛牛下在第 11 行第 22 列;
  • 菲菲下在第 22 行第 11 列;
  • 牛牛下在第 11 行第 33 列;
  • 菲菲下在第 22 行第 22 列;
  • 牛牛下在第 22 行第 33 列(这是这一步时唯一可以落子的格子);
  • 填满棋盘,游戏结束,盘面如下。

菲菲的得分为:2 + 9 + 1 = 122+9+1=12;牛牛的得分为:7 + 2 + 1 = 107+2+1=10。

数据范围与提示

对于所有的测试数据,n, m \leq 10, A_{i,j}, B_{i,j} \leq 100000n,m≤10,Ai,j​,Bi,j​≤100000。

对于编号为奇数的测试点,保证所有的 B_{i,j} = 0Bi,j​=0。

测试点 n=n= m=m=
1,2,31,2,3 22 22
4,5,64,5,6 33 33
7,87,8 55 55
9,109,10 88 88
11,1211,12 1010 11
13,1413,14 1010 22
15,1615,16 1010 33
17,18,19,2017,18,19,20 1010 1010

来源

CCF 2018省选Day1


Solution
一个合法的状态一定是一个左上角,也就是一条从左下走到右上的路线。
那么就是C(20,10)似乎不大。
考虑用hash压缩状态,记搜转移。
似乎跑的非常慢,还好oj快

  1. #include<cstdio>
  2. #include<iostream>
  3. #include<cstdlib>
  4. #include<cstring>
  5. #include<algorithm>
  6. #include<cmath>
  7. #include<unordered_map>
  8. #define ll unsigned long long
  9. #define p 793999
  10. using namespace std;
  11. int n,m,a[][],b[][],tmp[];
  12. unordered_map<ll,int>f,g,s[];
  13. ll get(){
  14. ll H=;
  15. for(int i=;i<=n;i++){
  16. H=H*p+tmp[i];
  17. }
  18. for(int i=;i<=m;i++)s[i][H]=tmp[i];
  19. return H;
  20. }
  21. void dfs(int x,ll k){
  22. if(x==n*m+){f[k]=;return;}
  23. if(g[k])return ;g[k]=;
  24. for(int i=;i<=m;i++)tmp[i]=s[i][k];
  25. int Mx=-1e9,Mi=1e9;
  26. if(tmp[]<m){
  27. tmp[]++;ll nx=get();dfs(x+,nx);
  28. Mx=max(Mx,f[nx]+a[][tmp[]]);
  29. Mi=min(Mi,f[nx]-b[][tmp[]]);
  30. tmp[]--;
  31. }
  32. for(int i=;i<=n;i++){
  33. if(tmp[i]<tmp[i-]){
  34. tmp[i]++;ll nx=get();dfs(x+,nx);
  35. Mx=max(Mx,f[nx]+a[i][tmp[i]]);
  36. Mi=min(Mi,f[nx]-b[i][tmp[i]]);
  37. tmp[i]--;
  38. }
  39. }
  40. if(x&)f[k]=Mx;else f[k]=Mi;
  41. }
  42. int main(){
  43. cin>>n>>m;
  44. for(int i=;i<=n;i++)
  45. for(int j=;j<=m;j++)scanf("%d",&a[i][j]);
  46. for(int i=;i<=n;i++)
  47. for(int j=;j<=m;j++)scanf("%d",&b[i][j]);
  48. dfs(,);
  49. cout<<f[]<<endl;
  50. return ;
  51. }
 

一双木棋(chess)的更多相关文章

  1. 洛谷P4363 一双木棋 chess

    洛谷P4363 一双木棋 chess 省选最水的一道题了. 且看我数个月AC一道题...... 具体是这样的:我们发现这个下了棋的地方一定形成一个锯齿形,那么怎么状态压缩呢? 维护轮廓线! 从左下角出 ...

  2. 洛谷 P4363 [九省联考2018]一双木棋chess 解题报告

    P4363 [九省联考2018]一双木棋chess 题目描述 菲菲和牛牛在一块\(n\)行\(m\)列的棋盘上下棋,菲菲执黑棋先手,牛牛执白棋后手. 棋局开始时,棋盘上没有任何棋子,两人轮流在格子上落 ...

  3. 洛谷P4363 [九省联考2018]一双木棋chess 【状压dp】

    题目 菲菲和牛牛在一块n 行m 列的棋盘上下棋,菲菲执黑棋先手,牛牛执白棋后手. 棋局开始时,棋盘上没有任何棋子,两人轮流在格子上落子,直到填满棋盘时结束. 落子的规则是:一个格子可以落子当且仅当这个 ...

  4. 【题解】Luogu P4363 [九省联考2018]一双木棋chess

    原题传送门 这道题珂以轮廓线dp解决 经过推导,我们珂以发现下一行的棋子比上一行的棋子少(或等于),而且每一行中的棋子都是从左向右依次排列(从头开始,中间没有空隙) 所以每下完一步棋,棋盘的一部分是有 ...

  5. [九省联考2018] 一双木棋 chess

    Description 菲菲和牛牛在一块n 行m 列的棋盘上下棋,菲菲执黑棋先手,牛牛执白棋后手. 棋局开始时,棋盘上没有任何棋子,两人轮流在格子上落子,直到填满棋盘时结束. 落子的规则是:一个格子可 ...

  6. BZOJ.5248.[九省联考2018]一双木棋chess(对抗搜索 记忆化)

    BZOJ 洛谷P4363 [Update] 19.2.9 重做了遍,感觉之前写的有点扯= = 首先棋子的放置情况是阶梯状的. 其次,无论已经放棋子的格子上哪些是黑棋子哪些是白棋子,之前得分如何,两人在 ...

  7. Luogu4363 [九省联考2018]一双木棋chess 【状压DP】【进制转换】

    题目分析: 首先跑个暴力,求一下有多少种状态,发现只有18xxxx种,然后每个状态有10的转移,所以复杂度大约是200w,然后利用进制转换的技巧求一下每个状态的十进制码就行了. 代码: #includ ...

  8. luogu P4363 [九省联考2018]一双木棋chess

    传送门 对抗搜索都不会,我真是菜死了qwq 首先根据题目条件,可以发现从上到下每一行的棋子数是单调不增的,然后n m都比较小,如果把状态搜出来,可以发现合法状态并不多,所以可以用一个11进制数表示状态 ...

  9. [九省联考2018]一双木棋chess

    题解: 水题吧 首先很显然的是状压或者搜索 考虑一下能不能状压吧 这个东西一定是长成三角形的样子的 所以是可以状压的 相邻两位之间有几个0代表他们差几 这样最多会有2n 然后就可以转移了 由于之前对博 ...

  10. 洛谷P4363 一双木棋chess [九省联考2018] 搜索+hash

    正解:记搜+hash 解题报告: 传送门! 因为看到nm范围特别小,,,所以直接考虑爆搜(bushi 先考虑爆搜之后再想优化什么的嘛QwQ 首先对这种都要最优的,就可以直接把答案设为针对某一方,然后题 ...

随机推荐

  1. Validform验证插件

    http://validform.club/index.html

  2. mac安装pip并升级pip版本

      最近想安装inchat,直接使用命令pip install install,结果提示 使用提示中的命令升级,结果提示找不到pip.很郁闷,明明有pip,结果一升级还给升没了.最后用的是这个方法完美 ...

  3. Node.js实战4:标准IO及console对像。

    IO即输入输出. console用于Nodejs程序信息输出. Nodejs的IO操作,通过process.stdout.process.stdin来操作. 下面的例子,将简单展示这两个函数的用法.程 ...

  4. win10下装win7双系统安装教程

    win10下装win7双系统安装教程 来源:www.laomaotao.org 时间:2017-02-13 10:15 新买的电脑预装了win10系统,但win10对于有些游戏兼容性不是很好,总是会出 ...

  5. FireFox浏览器导出文件名乱码

    解决方案1 String codedFileName = "导出文件名.xls"; String agent = request.getHeader("USER-AGEN ...

  6. 【转载】sizeof()、strlen()、length()、size()详解和区别

    c/c++中获取字符串长度.有以下函数:size().sizeof() .strlen().str.length();一.数组或字符串的长度:sizeof().strlen()1.sizeof():返 ...

  7. 针对三星Exynos CPU Root漏洞

    因为系统为了保护这些符号地址泄露,而用的一种保护手段,从而使除root用户外的普通用户不能直接查看符号地址: 原因在于内核文件kallsyms.c中的显示符号地址命令中做了如下限制: seq_prin ...

  8. tomcat内存使用情况

    预发布阿里云服务器的容器 tomcat会自己无缘无故重启,故引出一些查看tomcat内存使用情况观察的细枝末节: 1️⃣当前端口号进程信息和GC使用情况(1)显示端口的PID:lsof -i:端口示例 ...

  9. 阿里云云监控agent插件 - Linux版

    阿里云云监控agent插件使用指南 1.安装(注意,要以“root”权限运行,复制 sudo后面的就行,别把#也复制进去) #64位 # sudo bash -c "wget -e 'htt ...

  10. 各种设备在linux中的文件名

    各种设备在linux中的文件名: 设备         设备在linux内的文件名 ide硬盘 /dev/ha[a-d] scs硬盘 /dev/sd[a-p] u盘 /dev/sd[a-p](与SAT ...