题目地址: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的更多相关文章

  1. CF1153E Serval and Snake(交互题)

    题目 CF1153E Serval and Snake 很有意思的一道交互题 做法 我们观察到,每次查询一行,当这一行仅包含一端是返回的答案是奇数 根据这个性质查询每一行每一列,我们大体能知道两端的位 ...

  2. CF1153E Serval and Snake【构造】

    题目链接:洛谷 这道题是很久以前NTF跟我说的,现在想起来把它做了... 我们发现,如果蛇的两头都在矩形里或矩形外,则询问为偶数,否则为奇数. 所以我们询问每一行和每一列,就能知道蛇的两头的横纵坐标了 ...

  3. Codeforces Round #551 (Div. 2) E. Serval and Snake (交互题)

    人生第一次交互题ac! 其实比较水 容易发现如果查询的矩阵里面包含一个端点,得到的值是奇数:否则是偶数. 所以只要花2*n次查询每一行和每一列,找出其中查询答案为奇数的行和列,就表示这一行有一个端点. ...

  4. Codeforces Round #551 (Div. 2) EF Solution

    E. Serval and Snake 对于一个矩形,如果蛇的一条边与它相交,就意味着这条蛇从矩形内穿到矩形外,或者从矩形外穿到矩形内.所以如果某个矩形的答案为偶数,意味着蛇的头尾在矩形的同一侧(内或 ...

  5. 【Codeforces】Codeforces Round #551 (Div. 2)

    Codeforces Round #551 (Div. 2) 算是放弃颓废决定好好打比赛好好刷题的开始吧 A. Serval and Bus 处理每个巴士最早到站且大于t的时间 #include &l ...

  6. Codeforces Round #551 (Div. 2) A-E

    A. Serval and Bus 算出每辆车会在什么时候上车, 取min即可 #include<cstdio> #include<algorithm> #include< ...

  7. Codeforces Round #551 (Div. 2) A~E题解

    突然发现上一场没有写,那就补补吧 本来这场应该5题的,结果一念之差E fail了 A. Serval and Bus 基本数学不解释,假如你没有+1 -1真的不好意思见人了 #include<c ...

  8. [LeetCode] Design Snake Game 设计贪吃蛇游戏

    Design a Snake game that is played on a device with screen size = width x height. Play the game onli ...

  9. Leetcode: Design Snake Game

    Design a Snake game that is played on a device with screen size = width x height. Play the game onli ...

随机推荐

  1. Django学习笔记之表单验证

    表单概述 HTML中的表单 单纯从前端的html来说,表单是用来提交数据给服务器的,不管后台的服务器用的是Django还是PHP语言还是其他语言.只要把input标签放在form标签中,然后再添加一个 ...

  2. Java Lucene入门

    1.lucene版本:7.2.1 pom文件: <?xml version="1.0" encoding="UTF-8"?> <project ...

  3. 服务网关Ocelot 入门Demo系列(01-Ocelot极简单Demo及负载均衡的配置)

    [前言] Ocelot是一个用.NET Core实现并且开源的API网关,它功能强大,包括了:路由.请求聚合.服务发现.认证.鉴权.限流熔断.并内置了负载均衡器与Service Fabric.Butt ...

  4. Python Revisited Day 07 (文件处理)

    目录 7.1 二进制数据的读与写 7.1.1 带可选压缩的Pickle 7.1.2 带可选压缩的原始二进制数据 7.2 文本文件的写入与分析 7.2.1 写入文本 7.2.2 分析文本 7.2.3 使 ...

  5. codeforces#1011C. Fly (二分,注意精度)

    题意:火箭经过1到n号星球,并回到1号星球,现在给出每消耗一砘燃油能带起的火箭质量a[i]和b[i],a[i]代表在第i个星球起飞,b[i]代表在第i个星球降落.求出最少消耗的汽油.保证:如果不能完成 ...

  6. LoadRunner 压力测试使用基础步骤

    一.新建脚本 二.新建脚本-选择协议,这里选择Web (HTTP/HTML) 三.开始录制(指定程序与URL) 四.场景设计(设计虚拟用户访问场景) 五.运行情况(可以看到运行结果) 六.分析报告(总 ...

  7. Jenkins下载历史Build版本的归档文件

    /root/.jenkins/jobs/zgg-crm-pre/builds//com.zgg$crm/archive/com.zgg/crm/0.0.1/crm-0.0.1.war https:// ...

  8. Python——匿名函数

    一.定义: 是指一类无需定义标识符(函数名)的函数或子程序 二.语法格式: lambda 参数:表达式 三.注意事项: lambda 函数可以接收任意多个参数 (包括可选参数) 并且返回单个表达式的值 ...

  9. 映美FP-530K+打印发票卡纸

    最近打发票卡纸了几次,只能作废掉,硬件不太好排查,卡纸都是在发票的中间位置,我在卡纸的时候观察了好几次,打开打印机盖子,直接裸露这样看里面的打印状况,目前发现了两种卡纸位置. 如图,一种是后面的黑色塑 ...

  10. ObjectARX® for Beginners: An Introduction

    转:ObjectARX® for Beginners: An Introduction Lee Ambrosius – Autodesk, Inc.         CP4164-L    Objec ...