这里有一道老实题,大家快来踩爆它!

交互题:根据你的输出决定下一次的输入。

请听题:

管理员有个乱序数列(举例:{14, 24, 9, 19}),排序以后是个等差数列({9, 14, 19, 24}),现在他只告诉你有n个数(样例n = 4)却不给你数列,让你求出最小的那个数(9)和公差d(5)。

而你可以在不超过60次的询问之后再给出结果,询问有两种方式:

1.    输出“> x”,暗示是否存在大于x的数,如果存在,管理员回复“1”,否则回复“0”。(这个回复自己读入一下谢谢~)

2.    输出“? i”,请求查询乱序数列第i个数是几,然后管理员会告诉你哒。

最后你得到结果后最终输出“! minnum d”。

样例:

input:

4

(注意以下输入数据是对应你的输出的)

0

1

14

24

9

19

output:
> 25(之后有了输入0)

> 15(之后有了输入1)

? 1 (之后有了输入14)

? 2

? 3

? 4

! 9 5(这个就是答案了)

题解:

头一次遇到这么简单的E题大家自己AC吧全剧终。

好,大家A掉了以后我来分享一下我做这个题的思路历程:

首先自鸣得意地想到如果数列长度不足60那在下岂不是厚着脸皮问出来就行了……于是有了下面这段代码:

 void work1() {
for (int i = ; i <= n; i++) {
printf("? %d\n", i);
fflush(stdout);
scanf("%d", &a[i]);
}
sort(a + , a + + n);
printf("! %d %d\n", a[], a[] - a[]);
} int main() {
scanf("%d", &n);
if (n <= ) work1();

然后果然这段代码是没卵用的,还是要想个更一般的方法。

那么根据这题的询问模式我们不难意淫到这样一个场景:你让心仪的妹子心中默念一个1~2147483647的数字,因为不忍心拒绝激动而又熟稔地背出一串奇怪数字的你,正在和吴彦祖聊天的妹子于是默念520。好的君已入瓮,你遂使出了(非)计算机专业引以为傲的“二分莽猜之术”猜了二三十次以后猜到了答案并说了出来,然后……

然后AlphaWA过来问你可以用这种方法得到最小值咩?啊不能。but问个log1e9(≈30)次总能得到个最大值了对吧?

好,好。30是60的一半,这路子很稳。有了最大值和项数,根据小学奥数知识我们不难搞出最小值了。

那么剩下的30次询问怎么用呢?可以得到其中的一些数喽。于是有了以下思考历程:

1.    用30次可以抽到(排序后)连续的两个数吗,这样公差d就出来了?欧皇可,非酋不可。

2.    那能搞到第二大的值吗,道理同上?回答同上。

3.    emmm那随便来几个数,有什么办法搞到d?唔,他们的差一定是d的倍数,gcd一遍就好啦!

4.    稳吗?不稳,比如2,4,6,8,10,12,我们如果抽到4,8,12,会得到d = 4这一错误结果。

5.    所以根据大数据的原理(大雾),数字越多错误率越低,且请随机抽取,免得有规律抽取被一些居心不良的红名同学出一组针对数据hack掉。

嗯,那就做完了。参考代码,请无视掉:小家子气的60以下特判、写1024次1024个模样的二分、未使用mt19937的乡下随机。

 #include <bits/stdc++.h>
using namespace std; int n, d, maxx;
int a[];
bool mark[]; int random(int n) {
return (double)rand()/RAND_MAX * n + 0.5;
} void work1() {
for (int i = ; i <= n; i++) {
printf("? %d\n", i);
fflush(stdout);
scanf("%d", &a[i]);
}
sort(a + , a + + n);
printf("! %d %d\n", a[], a[] - a[]);
} int main() {
scanf("%d", &n);
if (n <= ) work1();
else {
int l = , r = 1e9, cnt = ;
while (l < r) {//二分莽猜
int mid = (l + r) >> ;
printf("> %d\n", mid);
fflush(stdout);
cnt++;
scanf("%d", &d);
if (d) l = mid + , maxx = l;
else r = mid;
}
//随机序列
srand(time());
for (int i = cnt + ; i <= ; i++) {
d = ;
do {
mark[d] = true;
d = random(n) + ;
} while (mark[d]);
printf("? %d\n", d);
fflush(stdout);
scanf("%d", &a[i]);
}
sort(a + cnt + , a + );
//gcd
d = a[cnt+] - a[cnt+];
for (int i = cnt + ; i <= ; i++) {
d = __gcd(d, a[i] - a[i-]);
}
printf("! %d %d\n", maxx - (n-) * d, d);
}
return ;
}

奉上御用std:

 #pragma comment(linker, "/stack:247474112")
#pragma GCC optimize("Ofast") #include <bits/stdc++.h>
using namespace std; #define endl '\n'
mt19937 rng32(chrono::steady_clock::now().time_since_epoch().count()); int n, Max = -, d = ;
int queryRemaining = ; vector<int> id; void findMax() {
int top = -, bot = +;
while (top <= bot) {
int hasHigher;
int mid = (top + bot) / ;
cout << "> " << mid << endl;
fflush(stdout); cin >> hasHigher;
queryRemaining--;
if (hasHigher) top = mid + ;
else {bot = mid - ; Max = mid;}
}
} void findD() {
vector<int> List; int RandomRange = n;
while (queryRemaining > && RandomRange > ) {
int demandedIndex = rng32() % RandomRange;
cout << "? " << id[demandedIndex] << endl; fflush(stdout);
int z; cin >> z; List.push_back(z);
RandomRange--; queryRemaining--;
swap(id[demandedIndex], id[RandomRange]);
}
sort(List.begin(), List.end());
if (List.back() != Max) List.push_back(Max);
for (int i=; i<List.size(); i++) {
d = __gcd(d, List[i] - List[i-]);
}
} void Input() {
cin >> n; id.resize(n);
for (int i=; i<n; i++) id[i] = i+;
} void Solve() {
findMax(); findD();
int Min = Max - d * (n - );
cout << "! " << Min << " " << d;
cout << endl; fflush(stdout);
} int main(int argc, char* argv[]) {
ios_base::sync_with_stdio();
Input(); Solve(); return ;
}

Codeforces 1114E(简单交互)的更多相关文章

  1. cocos2d-x lua与c++简单交互

    cocos2d-x lua与c++简单交互 version: cocos2d-x 3.6 本文讲述lua与c++的一些简单交互: lua通过消息方式调用c++无参接口 c++调用lua带参接口 1.通 ...

  2. unity3d和php后台简单交互--二

    上次我们讨论了u3d和php的简单交互,现在我们接着讨论u3d和php交互,这里我们讨论的是php的后台大家可以延伸为其他语言.在实现的开发中我们很少通过发送字符或者字段到服务器上的,我们一般会请求包 ...

  3. unity3d和php后台简单交互--一

    unity3d开发时,用PHP作为后台是个不错的选择.对一些数据吞吐量不是很大的游戏,比如某个游戏的排名,登录等等,一般的php程序能够胜任了,并且php语言简单,开发容易对数据库尤其是mysql的支 ...

  4. python和mongodb简单交互

    python和mongodb简单交互 1.安装pymongo: pip3 install pymongo 2.pymongo的简单用法: # /usr/bin/env python3 import p ...

  5. python和redis简单交互

    python和redis简单交互 1.安装redis模块 pip3 install redis 2.redis模块简单使用: # /usr/bin/env python3 import redis c ...

  6. 学习HTML 第五节.简单交互 加个按钮

    学习HTML 第五节.简单交互 也许你和我一样,对页面排版的兴趣小于网页交互,那么我们就先略过一些章节,直接先学一下简单交互. 前面点击图片打开链接的网址,已经是最简单的交互方式了,复杂的方式则需要用 ...

  7. 2020年的UWP(3)——UWP和desktop extension的简单交互

    上一篇<2020年的UWP(2)--In Process App Service>中我们了解了UWP和Desktop Extension可以通过AppService进行数据交互.本篇我们就 ...

  8. java,js,jstl,EL的简单交互

    EL全名Expression Language.EL提供了在JSP脚本编制元素范围外使用运行时表达式的功能. 脚本编制元素是指页面中能够用于在JSP文件中嵌入java代码的元素. JSP标准标记库(j ...

  9. Codeforces 1114E - Arithmetic Progression - [二分+随机数]

    题目链接:http://codeforces.com/problemset/problem/1114/E 题意: 交互题,有一个 $n$ 个整数的打乱顺序后的等差数列 $a[1 \sim n]$,保证 ...

随机推荐

  1. Vue实战指南之依赖注入(provide / inject)

    案例 UI美眉说咱家的选项菜单太丑了,小哥哥能不能美化一下呀,洒家自然是说小意思啦~自定义一个select组件,so easy~ 简单粗暴型: <el-select v-model=" ...

  2. HTML预览 正则替换

    1. [代码][PHP]代码  <?php    if(!defined('BASEPATH')) exit('No direct script access allowed');    /** ...

  3. 洛谷【P839】【NOI导刊】——数页码

    题面 一道找规律好题... 首先,我们肯定只能一位一位的统计答案,考虑从高位向低位统计,显然这样要方便的多. 对于第i位,我们统计从$a[i+1]*10^i+0$到$a[i+1]*10^i+a[i]* ...

  4. PHP自定义网站根目录

    1.打开httpd.conf配置文件(xampp下apache文件夹中的conf里) Ctrl + F 查找documentroot 找到结果 改好后保存,并重启apache

  5. 记一次关于return的错误

     有时候瞎JB程序,调一天东改西改,都发现不了错:到最后弄出来发现就是那样一个SB错误,真不知道该笑还是该哭. 这个if语句中的return,如果加了那么判断了if语句成立后,下面就不再执行了.   ...

  6. Asterisk 通话过程中执行动作(即applicationmap )的使用方法和电话转会议的实现

      asterisk在正常通话过程中执行拨号计划中动作是通过feature.conf中的[applicationmap ]下定义的,举例如下: nway-start => *0,callee,M ...

  7. PHP 时间戳

    <?php php 获取今日.昨日.上周.本月的起始时间戳和结束时间戳的方法,主要使用到了 php 的时间函数 mktime.下面首先还是直奔主题以示例说明如何使用 mktime 获取今日.昨日 ...

  8. Kefa and Watch

    题意: 维护一个长度为n的字符串,两种操作: 1.将 [l,r] 的字符变为 c 2.询问 d 是否为 $S(l,r)$ 的周期 解法: 首先分析如何令 [l,r] 的周期为d,利用循环串的性质得: ...

  9. 【Linux学习】Linux文件系统1--文件系统的目录结构

    Linux文件系统1--文件系统的目录结构 一.linux文件系统的类型 LINUX有四种基本文件系统类型:普通文件.目录文件.连接文件和特殊文件,可用file命令来识别. 1.普通文件:如文本文件. ...

  10. Flutter实战视频-移动电商-37.路由_Fluro引入和商品详细页建立

    37.路由_Fluro引入和商品详细页建立 https://github.com/theyakka/fluro pages/details_page.dart新建页面 使用路由 先添加路由插件的引用 ...