[BJOI2018]双人猜数游戏
题解:
彻彻底底的思维题???还是挺难的。。
首先连样例解释都没给。。没看题解搞了很久
大概就是
一个人要根据另一个人的决策来猜数
可以去看洛谷那篇题解的解释
然后我们用$f[A/B][i][j][k]$
表示第i次操作时,$A/B$能否判断出(j,k)
然后这个挺好dp
另外如果$f[i-1][xx]$可以的话$f[i][xx]$也一定可以
后面要注意两种情况
1.扩展出当前情况的时候
一定要满足其他的已经扩展出,但是当前的没有扩展出(因为这个查了很久)
2.最后一次扩展的时候,如果只能多扩展出这一个,那也是可行的
这个不知道第一个样例就过不了
另外答案是两个之和最小。。。
25组也就1s左右吧
代码:
#include <bits/stdc++.h>
using namespace std;
#define rint register int
#define IL inline
#define rep(i,h,t) for (int i=h;i<=t;i++)
#define dep(i,t,h) for (int i=t;i>=h;i--)
#define me(x) memset(x,0,sizeof(x))
int n,m;
const int M=;
bool f[][M][M];
char cc[];
IL bool pd1(bool (*f) [M],int k,int now)
{
rep(i,m,k)
{
int j=k-i;
if (i>j) break;
if (now!=i&&!f[i][k-i]) return();
}
if (!f[now][k-now]) return();
else return();
}
IL bool pd2(bool (*f) [M],int k,int now)
{
rep(i,m,k)
{
int t=k/i;
if (i>t) break;
if (t*i==k)
if (now!=i&&!f[i][t]) return();
}
if (!f[now][k/now]) return();
else return();
}
IL bool pd3(bool (*f1) [M],bool (*f2) [M],int k,int now)
{
rep(i,m,k)
{
int j=k-i;
if (i>j) break;
if (now!=i&&f1[i][k-i]!=f2[i][k-i]) return();
}
if (f2[now][k-now]&&!f1[now][k-now]) return();
else return();
}
IL bool pd4(bool (*f1) [M],bool (*f2) [M],int k,int now)
{
rep(i,m,k)
{
int t=k/i;
if (i>t) break;
if (t*i==k)
if (now!=i&&f1[i][t]!=f2[i][t]) return();
}
int t=k/now;
if (f2[now][t]&&!f1[now][t]) return();
else return();
}
int main()
{
rep(tt,,)
{
me(f);
char c1[]="guess";
int now=;
if (tt>=) c1[++now]=tt/+,c1[++now]=tt%+;
else c1[++now]=tt%+;
c1[++now]='.'; c1[++now]='i'; c1[++now]='n'; char c2[]="guess";
now=;
if (tt>=) c2[++now]=tt/+,c2[++now]=tt%+;
else c2[++now]=tt%+;
c2[++now]='.'; c2[++now]='o'; c2[++now]='u'; c2[++now]='t';
freopen(c1,"r",stdin);
freopen(c2,"w",stdout);
ios::sync_with_stdio(false);
cin>>n>>cc>>m;
swap(n,m);
int tf;
if (cc[]=='B') tf=; else tf=;
if (!tf)
{
rep(i,,M)
rep(j,,M)
if (i<=j&&i>=m&&j>=m)
if (pd1(f[],i+j,i)) f[][i][j]=;
rep(i,,M)
rep(j,,M)
if (i<=j&&i>=m&&j>=m)
if (pd2(f[],i*j,i)) f[][i][j]=;
} else
{
rep(i,,M)
rep(j,,M)
if (i<=j&&i>=m&&j>=m)
if (pd2(f[],i*j,i)) f[][i][j]=;
rep(i,,M)
rep(j,,M)
if (i<=j&&i>=m&&j>=m)
if (pd1(f[],i+j,i)) f[][i][j]=;
}
rep(k,,n+)
{
rep(i,,M)
rep(j,,M)
f[k][i][j]=f[k-][i][j];
if ((k+tf)%==)
{
rep(i,,M)
rep(j,,M)
if (i<=j&&i>=m&&j>=m)
if (pd1(f[k-],i+j,i)) f[k][i][j]=;
}
else
rep(i,,M)
rep(j,,M)
if (i<=j&&i>=m&&j>=m)
if (pd2(f[k-],i*j,i)) f[k][i][j]=;
}
rep(i,,M)
rep(j,,M)
if (i>=m&&j>=m)
if ((n+tf)%==)
{
if (pd3(f[n-],f[n+],i+j,i)) f[n][i][j]=;
} else
{
if (pd4(f[n-],f[n+],i*j,i)) f[n][i][j]=;
}
n++;
int mina=1e9,minb=1e9;
rep(i,,M)
rep(j,,M)
if (f[n][i][j]&&f[n-][i][j]&&!f[n-][i][j]&&!f[n-][i][j]&&((i+j<mina+minb)||((i+j)==mina+minb&&(i<mina))))
{
mina=i,minb=j;
}
cout<<mina<<" "<<minb<<endl;
int a;
}
return ;
}
[BJOI2018]双人猜数游戏的更多相关文章
- [luogu4459][BJOI2018]双人猜数游戏(DP)
https://zhaotiensn.blog.luogu.org/solution-p4459 从上面的题解中可以找到样例解释,并了解两个人的思维方式. A和B能从“不知道”到“知道”的唯一情况,就 ...
- 洛谷P4459/loj#2511 [BJOI2018]双人猜数游戏(博弈论)
题面 传送门(loj) 传送门(洛谷) 题解 所以博弈论的本质就是爆搜么-- 题解 //minamoto #include<bits/stdc++.h> #define R registe ...
- 【洛谷4459】[BJOI2018] 双人猜数游戏(动态规划)
点此看题面 大致题意: 一直有两个数\(m,n\),已知\(s\le m\le n\),且\(Alice\)和\(Bob\)二个"最强大佬"各知道\(mn\)和\(m+n\).每轮 ...
- 【LOJ】#2511. 「BJOI2018」双人猜数游戏
题解 设\(f[p][a][b]\)表示询问了\(p\)次,答案是\(a,b\)是否会被猜出来 然后判断如果\(p = 1\) 第一个问的\(Alice\),那么\([s,\sqrt{nm}]\)约数 ...
- 【BZOJ 1594】 [Usaco2008 Jan]猜数游戏 (二分+并查集)
1594: [Usaco2008 Jan]猜数游戏 Description 为了提高自己低得可怜的智商,奶牛们设计了一个新的猜数游戏,来锻炼她们的逻辑推理能力. 游戏开始前,一头指定的奶牛会在牛棚后面 ...
- usaco 猜数游戏
Description 为了提高智商,锻炼思维能力,奶牛设计了一个猜数游戏.游戏开始前,贝西会在牛棚后面摆上N个数字.所有数字排成一条直线,按次序从1到N编号.每个数字在1到10^9之间,没有两个数字 ...
- (一)Python之猜数游戏
猜数游戏由简如深的编码学习过程: 3次机会: print('------------------我爱鱼C工作室------------------')count=0while count < 3 ...
- 猜数游戏-flag的运用
package my;import java.util.Scanner;public class MyJava { public static void main(String[] ar ...
- Java课程设计——猜数游戏(201521123111 陈伟泽)
Java课程设计--猜数游戏(201521123111 陈伟泽) 1.团队课程设计博客链接 博客作业--猜数游戏 2.个人负责模块或任务说明 Answer:一些基础界面的构造,排行榜的构造,用文件录入 ...
随机推荐
- Linux 网络侦错:无法联机原因分析
所谓的软件问题,绝大部分就是 IP 参数设定错误啊,路由不对啊,还有 DNS 的 IP 设定错误等等的, 这些问题都是属于软件设定啦!只要将设定改一改,利用一些侦测软件查一查,就知道问题出在哪里了!基 ...
- 037_nginx第三方扩展
一.ngx_func_limit_req.conf(nginx限制请求数配置) # limit req zone limit_req_zone $binary_remote_addr $http_us ...
- docker拉取镜像报错:net/http: TLS handshake timeout.
docker拉取镜像报错:net/http: TLS handshake timeout. 启动一个后台的busybox容器 [yunva@node1 network-scripts]$ docker ...
- nodejs,javascript过滤emoj表情
1 前言 由于带emoj表情的昵称无法存储在mysql character_set_server= utf8模式下,按照参考文章[1],改成utf8mb4,无效(可能使用方法不对). 总体思路是,把昵 ...
- [JavaScript]iframe的contentWindow
HTMLIFrameElement.contentWindow返回的是HTMLIFrameElement类型元素的window对象 通过此对象可以修改iframe实体内的window行为 <if ...
- 洛谷P4859 已经没有什么好害怕的了 [DP,容斥]
传送门 思路 大佬都说这是套路题--嘤嘤嘤我又被吊打了\(Q\omega Q\) 显然,这题是要\(DP\)的. 首先思考一下性质: 为了方便,下面令\(k=\frac{n+k}{2}\),即有恰好\ ...
- VBS猜数游戏
VBS 猜数游戏 2018-11-09 21:19:11 by xutao msgbox "The Swami" ,,"Game" msgbox " ...
- Swift 学习- 08 -- 闭包
// 闭包是自包含的函数代码块, 可以在代码中被传递和使用, swift 中的闭包 与 C语言 和 OC 中的代码块 (blocks) 以及其他一些编程语言中的匿名函数比较类似 // 闭包可以捕获和存 ...
- Confluence 6 警告的类型
有下面的一些类型的警告. 警告和知识库(Alert and KB) 级别(Level) 默认阈值(Default threshold) 可配置(Configurable) Low free disk ...
- Confluence 6 为空白空间编辑默认主页
希望编辑默认(空白)空间内容模板: 在屏幕的右上角单击 控制台按钮 ,然后选择 General Configuration 链接. 在左侧的面板中选择 全局模板和蓝图(Global Templates ...