CodeForces 1063C. Dwarves, Hats and Extrasensory Abilities 交互

时间:2022-05-14 09:56:09

题目大意:

依次给定$n$个点的颜色,要求给定这$n$个点的坐标以及一条可以把他们分成两部分的直线

强制在线(交互)

$n \leqslant 30$

感觉自己真像一个乱搞...

我们只考虑把点放在最长的斜线$y = x$上

考虑$[0, 2^2]$,如果我们把第一个点放在$(0, 0)$上,那么后面根据返回的颜色是否与第一个点相同去二分,能放$3$个点

所以我们只需要$[0, 2^{29}]$就能放下30个点了

但是最后的白点和黑点的坐标差距只有$1$

这个时候,我们选取$y = -x + b \to x + y = b$

将$x, y$同时增加和减少0.5时,我们就能得到一个很不错的分割线

注意直线的端点一定要落在$[0, 10^9]$内,做了一些处理

连交互格式都不会的蒟蒻...

#include <queue>
#include <vector>
#include <cstdio>
#include <cstring>
#include <iostream>
#include <algorithm>
using namespace std;
char s[];
int l, r = << ;
int flag, lst, n, lp; inline char out(int x, int y) {
lp = x + ;
cout << x + << " " << y + << endl;
fflush(stdout);
cin >> s; return s[];
} inline void gz(int o) {
int p1 = o / - ;
int p2 = o / - ;
cout << p1 << " " << o - p1 << " ";
cout << p2 << " " << o - p2 << endl;
fflush(stdout);
} int main() {
cin >> n; n --;
flag = out(, );
while(n --) {
int mid = (l + r) >> ;
if(out(mid, mid) == flag) l = mid, lst = ;
else r = mid, lst = ;
}
if(lst) gz(lp * + );
else gz(lp * - );
return ;
}

CodeForces 1063C. Dwarves, Hats and Extrasensory Abilities 交互的更多相关文章

  1. Codeforces &num;1063C Dwarves&comma; Hats and Extrasensory Abilities

    题目大意 交互题. 输出平面上的一个点的坐标,交互程序给这个点染色(白或黑). 如此重复 $n$ 次($ 1\le n \le 30$). 要求输出的 $n$ 个点各不相同,并且不论交互程序怎样给它们 ...

  2. &lbrack;Codeforces Round &num;516&rsqb;&lbrack;Codeforces 1063C&sol;1064E&period; Dwarves&comma; Hats and Extrasensory Abilities&rsqb;

    题目链接:1063C - Dwarves, Hats and Extrasensory Abilities/1064E - Dwarves, Hats and Extrasensory Abiliti ...

  3. 【交互 细节题 思维题】cf1064E&period; Dwarves&comma; Hats and Extrasensory Abilities

    第一次做交互真有趣……:挺好的细节思维题 This is an interactive problem. In good old times dwarves tried to develop extr ...

  4. Dwarves&comma; Hats and Extrasensory Abilities Codeforces - 1063C

    https://codeforces.com/contest/1063/problem/C 首先可以想到一个简单做法:先钦定这个直线的斜率k=-1,然后设直线y=-x+b 设黑点放直线上方:如果已知( ...

  5. cf1064E&period; Dwarves&comma; Hats and Extrasensory Abilities&lpar;二分 交互&rpar;

    题意 题目链接 \(n\)次操作,每次你给出一个点的坐标,系统会返回该点的颜色(黑 / 白),程序最后输出一条直线把所有黑点和白点分隔开 Sol 一个很直观的想法:首先询问\((dx, 0)\),然后 ...

  6. CF1064 E - Dwarves&comma; Hats and Extrasensory Abilities

    题意 交互题, 本来应该是在平面上进行的. 实际上换成一条直线就可以, 其实换成在平面上更复杂一些. Solution 假设\(l\)点是黑点, \(r\)处是白点, 那么就把下一个点的位置放置在\( ...

  7. Codeforces Round &num;499 &lpar;Div&period; 2&rpar; D&period; Rocket&lowbar;交互题&lowbar;二分

    第一次作交互题,有点不习惯. 由于序列是循环的,我们可以将一半的机会用于判断当前是否是在说谎,另一半的机会用于二分的判断. 对于判断是否实在说谎,用1判断即可.因为不可能有比1还小的数. 本题虽然非常 ...

  8. Codeforces Round &num;504 E - Down or Right 交互题

    1023E 题意: 交互题.在一个有障碍地图中,问如何走才能从(1,1)走到(n,n),只能向右或者向左走.每次询问两个点,回复你这两个点能不能走通. 思路: 只用最多2*n-2次询问.从(1,1), ...

  9. Codeforces Round &num;551 &lpar;Div&period; 2&rpar; E 二分 &plus; 交互

    https://codeforces.com/contest/1153/problem/E 题意 边长为n的正方形里面有一条蛇,每次可以询问一个矩形,然后会告诉你蛇身和矩形相交有几部分,你需要在最多2 ...

随机推荐

  1. Game02 最新版本2&period;0&period;0

    Game02发布转站于此,欢迎大家下载.... 简介: Game02是由ImGenius开发的一款即时在线小游戏.玩法简单,易于上手,主要靠技术,不会出现不要脸的充值等内容. 操控方法:W和A左右移动 ...

  2. 修改mysql某一键为自增键

    alter table tb_name modify id int auto_increment primary key

  3. IOS - 真机测试

    转:版权声明:本文由本人亲自一步步完成,并细心排版生成,望广大同仁尊重一下本人的劳动成果,转载请注明出处,原文地址http://my.oschina.net/joanfen/blog/167730 一 ...

  4. jQuery通过jquery&period;form&period;js插件使用AJAX提交Form表单

    我简单使用了一下,jQuery Form插件有一下优点:  1.支持提交前验证. 2.支持提交后回调. 3.采用AJAX方式,有很好的用户体验 4.提交方式是灵活.只要指定要提交的form ID即可. ...

  5. HDU 4786 生成树 并查集&plus;极大极小值 黑白边 确定选择白边的数量

    题意: 给定一个无向图 n 个点 m条无向边 u v val val == 1 表示边(u, v) 为白边 问能否找到n个点的生成树, 使得白边数为斐波那契数 思路: 并查集求图是否连通( 是否存在生 ...

  6. SPPS java 创template

    最近写信给学校一个部门java plug for spss. 当加到变量超过70个月,然后保存,SPSS它会在错误的地方报. 解决方案: 每添加70提交变量. 版权声明:本文博主原创文章.博客,未经同 ...

  7. 第4章 同步控制 Synchronization ----事件(Event Objects)

    Win32 中最具弹性的同步机制就属 events 对象了.Event 对象是一种核心对象,它的唯一目的就是成为激发状态或未激发状态.这两种状态全由程序来控制,不会成为 Wait...() 函数的副作 ...

  8. Java工程读取resources中资源文件路径问题

    正常在Java工程中读取某路径下的文件时,可以采用绝对路径和相对路径,绝对路径没什么好说的,相对路径,即相对于当前类的路径.在本地工程和服务器中读取文件的方式有所不同,以下图配置文件为例. 本地读取资 ...

  9. python中的全局变量和局部变量

    python中,对于变量作用域的规定有些不一样. 在诸如C/C++.java等编程语言中,默认在函数的内部是能够直接訪问在函数外定义的全局变量的,可是这一点在python中就会有问题.以下是一个样例. ...

  10. Linux 简介&lpar;day1&rpar;

    一.Linux 诞生于1991年 二.创始人:林纳斯.托瓦茨(Linus Torvalds) 三.logo:企鹅 四.Linux完整系统包括 1.Linux kernel (Linux 内核) 2.f ...