还是自己水平不够,想了两天没想出来……(然后我就被其他人吊打了)

这种题目看了题解就秒会,自己想就想不出来……

下面是我的心路历程(我就在想出来又叉掉的不断循环中度过……)

开始把题目看成了查询限制 \(2N\) 长度,然后怎么也不会做,看看题,发现是 \(4N\) (然而还是不会做)

首先一个很显然的想法,就是先两步找出第一个,然后后面的每个都用一步。最后一位可能要多耗费一个。此时总步数正好是 \(N + 2\)。

然后重点就在中间的了。

我们记剩下来的字符为 \(A, B, C\),当前处理好的字符串为 \(S\)。

首先很容易有一个想法:在一个串后面加一堆同一个字符,然后看增加了多少,这样有概率一下子增加多个。

如果把所有连续的长度求出来,那么每次枚举只有两种情况,貌似很优秀。

于是构造 \(\{ S + A + \dots, S + B + \dots\}\),发现没填满,应该不对,于是改成 \(\{ S + A + A + \dots, S + A + B +\dots, S + B + A + \dots, S + B + B + \dots \}\) 。

然后发现对于下面是 \(A\) 和 \(B\) 的都很好求,只要分类讨论增加了几个。

但是一旦有 \(C\) 就会有额外枚举量,所以这种想法放弃了。

接着考虑如果不求最长连续的,对三种情况暴力算的也许可以。比如说可以改成不断的求子问题的模型。

仔细分析发现这样做本质和每次只增加 \(O(1)\) 个字符是相同的。

所以考虑每次增加那么多。

接下来我类似地考虑了这个加同一个字符。

也就是询问 \(\{ S + A + A + A, S + A + B + B, S + B + A + A, S + B + B + B \}\)

显然也可以通过分类讨论加了多少个的情况。

对于没加的;显然是 \(C\),对于加了 \(1\) 的,枚举第一位就可以知道第 \(2\) 位;对于加了 \(3\) 的,显然可以查询两次得到。对于这几种情况,得到每一个的耗费都是 \(1\)。

然而这个做法还是挂在加了 \(2\) 的,冷静分析,发现直接确定第三位还是更优的,但是马上发现你要用两步确定 \(8\) 种情况,然后GG。

所以发现我的做法对于只增加了两个的都凑不出来(总会多一步)。

凑了那么多,发现最后还是要找一个对于所有位数,情况平均少一点的。但是有一个 \(3\) 就显得难做了。


直到我看了题解:

我的做法太贪了,一次确定多位不太行,没有去想一次只确定一位……(这个故事告诉我们,做题尽量由浅入深,从简单的开始考虑)

和分类讨论加了多少个的思想类似,这个十分的暴力……

直接把下一个是 \(A\) 就 \(+2\), 是 \(B\) 就 \(+1\), 是 \(C\) 就 \(+0\),显然这个很好构造 \(\{ S + A + A, S + A + B, S + A + C, S + B\}\)

显然满足。

然后注意对剩下的只有一个的特判,正好补上最后的多的一个。

然后我把 \(<\) 写成 \(\leq\),WA了一发……

#include "combo.h"

const char sx[] = {'A', 'B', 'X', 'Y'};
std::string S, li[3];
std::string d(int at) {
return at == 3 ? S : li[at];
}
template<typename ... T>
std::string d(int at, T ... args) {
return (at == 3 ? S : li[at]) + d(args...);
}
std::string guess_sequence(int N) {
char fir = press("AB") >= 1 ? (press("A") ? 'A' : 'B') : (press("X") ? 'X' : 'Y');
S += fir; int bx = 0;
for (int i = 0; i < 4; ++i)
if (sx[i] != fir) li[bx++] = std::string(1, sx[i]);
for (bx = 1; bx < N; ) {
std::string qry;
if (bx + 1 == N) {
S += press(d(3, 0)) == N ? li[0] : (press(d(3, 1)) == N ? li[1] : li[2]);
break;
}
int res = press(d(3, 0, 0, 3, 0, 1, 3, 0, 2, 3, 1)) - bx;
if (!res) S += li[2];
else if (res == 1) S += li[1];
else if (res == 2) S += li[0];
++bx;
}
return S;
}

【IOI2018】组合动作的更多相关文章

  1. [IOI2018]组合动作

    IOI2018 组合动作 UOJ 首先显然可以两次试出首字母 考虑增量构造 假设首字母为A,且已经试出前i个字母得到的串s 我们考虑press这样一个串s+BB+s+BX+s+BY+s+XA 首先这个 ...

  2. [IOI2018]组合动作——构造

    题目连接: [IOI2018]combo 题目大意:有一个未知的长度为n的字符串$T$,只包含$A,B,X,Y$四个字符且首字母只出现一次,每一次你可以询问一个长度不超过$4n$的字符串$S$,交互库 ...

  3. LOJ.2863.[IOI2018]组合动作(交互)

    题目链接 通过两次可以先确定首字母.然后还剩下\(n-1\)位,之后每一位只有三种可能. 最简单的方法是每次确定一位,通过两次询问显然可以确定.但是只能一次询问. 首字母只会出现一次,即我们可以将串分 ...

  4. 【刷题】LOJ 2863 「IOI2018」组合动作

    题目描述 你在玩一个动作游戏.游戏控制器有 \(4\) 个按键,A.B.X 和 Y.在游戏中,你用组合动作来赚金币.你可以依次按这些按键来完成一个组合动作. 这个游戏有一个隐藏的按键序列,可以表示为由 ...

  5. Cocos2d-x手机游戏开发中-组合动作

    动作往往不是单一,而是复杂的组合.我们可以按照一定的次序将上述基本动作组合起来,形成连贯的一套组合动作.组合动作包括以下几类:顺序.并列.有限次数重复.无限次数重复.反动作和动画.动画我们会在下一节介 ...

  6. UOJ#405. 【IOI2018】组合动作

    原文链接https://www.cnblogs.com/zhouzhendong/p/IOI2018Day1T1.html 题解 首先二分一下,花费2次操作求出第一位的字符. 假设第一个字符是 Y,答 ...

  7. 【IOI 2018】Combo 组合动作(模拟,小技巧)

    题目链接 IOI的签到题感觉比NOI的签到题要简单啊,至少NOI同步赛我没有签到成功…… 其实这个题还是挺妙妙的,如果能够从题目出发,利用好限制,应该是可以想到的做法的. 接下来开始讲解具体的做法: ...

  8. [loj2863]组合动作

    先用两次猜出第一个字符,后面就不会出现这个字符了 (我们假设这个字符是c0,其余三种字符分别是c1.c2和c3) ,然后考虑已知s的前i个字符(不妨就s),来推出后面的字符 询问:s+c1和s+c2, ...

  9. 【WC2019笔记】IOI2018 / ACM题目选讲

    哇!济南的 rqy 大佬讲课!就是 $luogu$ 上有名的那位! 上面这句话写错了,请大家无视 XylophoneIOI2018 练习赛 T2题意:交互提有一个 $0\sim n-1$ 的排列,保证 ...

随机推荐

  1. Oracle-DDL 2- 视图&索引

    DDL-数据定义语句: 二.视图 --视图(view),本身不保存数据,保存的是一个查询语句--对视图的操作等同于对查询语句中源数据的操作--视图占用存储空间较小,可以快速的对特定数据进行访问和操作- ...

  2. springboot整合springdatajpa时jar冲突

    1.springboot整合springdatajpa测试时报No bean named 'entityManagerFactory' available错误 2.运行springboot主程序时报以 ...

  3. Java中的mutable和immutable对象实例讲解

    1.mutable(可变)和immutable(不可变)类型的区别 可变类型的对象:提供了可以改变其内部数据值的操作,其内部的值可以被重新更改. 不可变数据类型:其内部的操作不会改变内部的值,一旦试图 ...

  4. 设计模式:门面模式(Facade)

      前面介绍的适配器模式讲的是如何将一个接口转换成客户所需要的另一个接口,它的目的在于 解决接口的不兼容性问题.现在这里有这样一个模式,它的目的在于如何简化接口,它可以将多个类的复杂的一切隐藏在背后, ...

  5. nginx反向代理_负载均衡

    注意ip地址为: 虚拟机ip设置 TYPE="Ethernet"BOOTPROTO="static"NAME="enp0s3"DEVICE= ...

  6. 有关于eclipse启动调试时出现EOFexpetion错误的解决办法

    1.打开调试透视窗 2.找到所有断点 3.清空所有断点后再去打断点,再去调试 网上说法:这个问题可能是由于eclipse和tomcat的交互而产生的,在以debug模式启动tomcat时,发生了读取文 ...

  7. tp5.1中redis使用

    一.环境安装 1.下载redis,igbniary https://windows.php.net/downloads/pecl/releases/igbinary/ https://windows. ...

  8. React应该如何优雅的绑定事件?

    前言 由于JS的灵活性,我们在React中其实有很多种绑定事件的方式,然而,其实有许多我们常见的事件绑定,其实并不是高效的.所以本文想给大家介绍一下React绑定事件的正确姿势. 常见两种种错误绑定事 ...

  9. Leetcode简单题

    # Title Solution Acceptance Difficulty Frequency     1 Two Sum       44.5% Easy     2 Add Two Number ...

  10. 使用.NET Core创建Windows服务(一) - 使用官方推荐方式

    原文:使用.NET Core创建Windows服务(一) - 使用官方推荐方式 原文:Creating Windows Services In .NET Core – Part 1 – The &qu ...