CF1153E Serval and Snake
这是一道交互题
由于只需要确定起点和终点
你选择的矩形会将整个矩形分成的两个部分
如果起点和终点在同一个部分里,那么很显然回答应该是个偶数
反之则为奇数
因此我们可以先通过
int i;
for (i = 1; i < n; i++) {
printf("? 1 1 %d %d\n", n, i);
fflush(stdout);
scanf("%d", &x);
if (x & 1) break;
}
来确定起点和终点是否在同一列
如果不在同一列(即 \(i!=n\) ),那么 \(i\) 即为起点和终点这两个点中靠左的那个点所在的列
那么同理可以找到起点和终点这两个点中靠右的那个点所在的列
如果在同一列(即 \(i==n\) ) ,那么他们肯定不会在同一行(因为起点和终点是不同的点)
那么可以用同样的方法将两个点确定在两行内
现在已经能够锁定两个点在哪两条(行或列)了
在一条中确定一个点,二分再用奇偶判断即可
这样最坏的询问次数为 \(999+1000+10+10=2019\)
正好!
#include <bits/stdc++.h>
using namespace std;
int n, x, i, j;
int ax1, ay1, ax2, ay2;
int main() {
cin >> n;
for (i = 1; i < n; i++) {
printf("? 1 1 %d %d\n", n, i);
fflush(stdout);
scanf("%d", &x);
if (x & 1) break;
}
if (i != n) {
for (j = n; j > 1; j--) {
printf("? 1 %d %d %d\n", j, n, n);
fflush(stdout);
scanf("%d", &x);
if (x & 1) break;
}
int l = 1, r = n;
while (l < r) {
int mid = (l + r + 1) >> 1;
printf("? %d %d %d %d\n", mid, i, n, i);
fflush(stdout);
scanf("%d", &x);
if (x & 1) l = mid;
else r = mid - 1;
}
ax1 = l, ay1 = i;
l = 1, r = n;
while (l < r) {
int mid = (l + r + 1) >> 1;
printf("? %d %d %d %d\n", mid, j, n, j);
fflush(stdout);
scanf("%d", &x);
if (x & 1) l = mid;
else r = mid - 1;
}
ax2 = l, ay2 = j;
} else {
for (i = 1; i < n; i++) {
printf("? 1 1 %d %d\n", i, n);
fflush(stdout);
scanf("%d", &x);
if (x & 1) break;
}
for (j = n; j > 1; j--) {
printf("? %d 1 %d %d\n", j, n, n);
fflush(stdout);
scanf("%d", &x);
if (x & 1) break;
}
int l = 1, r = n;
while (l < r) {
int mid = (l + r + 1) >> 1;
printf("? %d %d %d %d\n", i, mid, i, n);
fflush(stdout);
scanf("%d", &x);
if (x & 1) l = mid;
else r = mid - 1;
}
ax1 = i, ay1 = l;
l = 1, r = n;
while (l < r) {
int mid = (l + r + 1) >> 1;
printf("? %d %d %d %d\n", j, mid, j, n);
fflush(stdout);
scanf("%d", &x);
if (x & 1) l = mid;
else r = mid - 1;
}
ax2 = j, ay2 = l;
}
printf("! %d %d %d %d\n", ax1, ay1, ax2, ay2);
return 0;
}
CF1153E Serval and Snake的更多相关文章
- CF1153E Serval and Snake(交互题)
题目 CF1153E Serval and Snake 很有意思的一道交互题 做法 我们观察到,每次查询一行,当这一行仅包含一端是返回的答案是奇数 根据这个性质查询每一行每一列,我们大体能知道两端的位 ...
- CF1153E Serval and Snake【构造】
题目链接:洛谷 这道题是很久以前NTF跟我说的,现在想起来把它做了... 我们发现,如果蛇的两头都在矩形里或矩形外,则询问为偶数,否则为奇数. 所以我们询问每一行和每一列,就能知道蛇的两头的横纵坐标了 ...
- Codeforces Round #551 (Div. 2) E. Serval and Snake (交互题)
人生第一次交互题ac! 其实比较水 容易发现如果查询的矩阵里面包含一个端点,得到的值是奇数:否则是偶数. 所以只要花2*n次查询每一行和每一列,找出其中查询答案为奇数的行和列,就表示这一行有一个端点. ...
- Codeforces Round #551 (Div. 2) EF Solution
E. Serval and Snake 对于一个矩形,如果蛇的一条边与它相交,就意味着这条蛇从矩形内穿到矩形外,或者从矩形外穿到矩形内.所以如果某个矩形的答案为偶数,意味着蛇的头尾在矩形的同一侧(内或 ...
- 【Codeforces】Codeforces Round #551 (Div. 2)
Codeforces Round #551 (Div. 2) 算是放弃颓废决定好好打比赛好好刷题的开始吧 A. Serval and Bus 处理每个巴士最早到站且大于t的时间 #include &l ...
- Codeforces Round #551 (Div. 2) A-E
A. Serval and Bus 算出每辆车会在什么时候上车, 取min即可 #include<cstdio> #include<algorithm> #include< ...
- Codeforces Round #551 (Div. 2) A~E题解
突然发现上一场没有写,那就补补吧 本来这场应该5题的,结果一念之差E fail了 A. Serval and Bus 基本数学不解释,假如你没有+1 -1真的不好意思见人了 #include<c ...
- [LeetCode] Design Snake Game 设计贪吃蛇游戏
Design a Snake game that is played on a device with screen size = width x height. Play the game onli ...
- Leetcode: Design Snake Game
Design a Snake game that is played on a device with screen size = width x height. Play the game onli ...
随机推荐
- 27 python 初学(信号量、条件变量、同步条件、队列)
参考博客: www.cnblogs.com/yuanchenqi/articles/5733873.html semaphore 信号量: condition 条件变量: event 同步条件:条件 ...
- 全文搜索引擎 ElasticSearch 还是 Solr?
最近项目组安排了一个任务,项目中用到了全文搜索,基于全文搜索 Solr,但是该 Solr 搜索云项目不稳定,经常查询不出来数据,需要手动全量同步,而且是其他团队在维护,依赖性太强,导致 Solr 服务 ...
- 在 CentOS 7 中安装 MySQL 8
准备 本文环境信息: 软件 版本 CentOS CentOS 7.4 MySQL 8.0.x 安装前先更新系统所有包 sudo yum update 安装 1. 添加 Yum 包 wget https ...
- 使用Roslyn脚本化C#代码,C#动态脚本实现方案
[前言] Roslyn 是微软公司开源的 .NET 编译器. 编译器支持 C# 和 Visual Basic 代码编译,并提供丰富的代码分析 API. Roslyn不仅仅可以直接编译输出,难能可贵的就 ...
- 全局css控制<td>标签属性
td { text-align: center; /*设置水平居中*/ vertical-align: middle; /*设置垂直居中*/ height:50px; / ...
- 如何查杀stopped进程
在Linux系统下面,top命令可以查看查看stopped进程.但是不能查看stopped进程的详细信息.那么如何查看stopped 进程,并且杀掉这些stopped进程呢? ps -e j | gr ...
- 安装appium桌面版和命令行版
一 桌面版(打开很慢,常用于辅助元素定位) 1.官网下载window版本: 2.直接点击紫色图标即可打开 3.启动server 二 命令行版(打开很快,常用于执行脚本) 1.jdk 安装jdk并 ...
- Python——字典操作
一.取出字典中所有的key-value student={'name':'xiaoming','age':11,'school':'tsinghua'} for key,value in studen ...
- 关于Qt的StyleSheet作用范围
Qt的StyleSheet是很方便的一个设置各种控件风格形态的属性,但是默认的StyleSheet会作用于所有的子控件,容易带来麻烦,以下几种情况,可以限制作用范围 以QTextEdit为例,实体名为 ...
- python利用selenium库识别点触验证码
利用selenium库和超级鹰识别点触验证码(学习于静谧大大的书,想自己整理一下思路) 一.超级鹰注册:超级鹰入口 1.首先注册一个超级鹰账号,然后在超级鹰免费测试地方可以关注公众号,领取1000积分 ...