当前位置: 首页 > news >正文

Luogu P14007 「florr IO Round 1」查询游戏 题解 [ 蓝 ] [ 交互 ]

查询游戏

原题做法是显然的,子段绝对值最大值可以转化为求出前缀和序列的最大值、最小值,然后两者作差即可。查询操作可以转化为询问前缀和序列中两个元素比大小。因为查询数 \(2n\),所以各扫一遍用擂台法求最大、最小值即可。

注意特判 Sub0 的 \(n = 1, 2\) 的情况:

  • \(n=1\),问前缀和序列中 \(P\)\(P_0, P_1\) 大小关系即可。
  • \(n=2\),问前缀和序列中 \(P\)\(P_0, P_1\)\(P_1, P_2\)\(P_0, P_2\) 大小关系即可。

考虑加强版,查询次数被限制在 \(\lfloor \dfrac{3n}{2}\rfloor\) 内的做法。有一个很实用的观察技巧:从小数据入手,通过小数据的情况覆盖大数据的情况

此题中 \(n = 1\) 时我们仅用 \(1\) 次比较就能分辨出他们的大小关系,所以对于原序列,我们将两个相邻的下标两两配对,像 \(n = 1\) 那样比较二者关系,把较大的放入 \(q1\) 中,小的放入 \(q2\) 中。其中 \(q1, q2\) 为两个队列。注意到 \(q1, q2\) 大小加起来只有 \(n\),所以直接打擂台扫过去,总查询次数为 \(\lfloor \dfrac{3n}{2}\rfloor\)

#include <bits/stdc++.h>
#define fi first
#define se second
#define eb(x) emplace_back(x)
#define pb(x) push_back(x)
#define lc(x) (tr[x].ls)
#define rc(x) (tr[x].rs)
using namespace std;
typedef long long ll;
typedef unsigned long long ull;
typedef long double ldb;
using pi = pair<int, int>;
int mxp = 0, mnp = 0, n;
bool res;
vector<int> mnv, mxv;
int main()
{cin >> n;if(n == 1){cout << "! 1 1" << endl;return 0;}if(n == 2){cout << "? 1 1" << endl;cin >> res;if(res == 1) mxp = 1;else mnp = 1;cout << "? " << mnp + 1 << " 2" << endl;cin >> res;if(res == 0) mnp = 2;cout << "? " << mxp + 1 << " 2" << endl;cin >> res;if(res == 1) mxp = 2;cout << "! " << min(mxp, mnp) + 1 << " " << max(mxp, mnp) << endl;return 0;}    for(int i = 1; i <= n; i += 2){cout << "? " << i << " " << i << endl;cin >> res;if(res == 0) mnv.push_back(i), mxv.push_back(i - 1);else mxv.push_back(i), mnv.push_back(i - 1);}if((n + 1) & 1) mxv.push_back(n), mnv.push_back(n);mnp = mnv[0], mxp = mxv[0];for(int i = 1; i < mnv.size(); i++){cout << "? " << mnp + 1 << " " << mnv[i] << endl;cin >> res;if(res == 0) mnp = mnv[i];}for(int i = 1; i < mxv.size(); i++){cout << "? " << mxp + 1 << " " << mxv[i] << endl;cin >> res;if(res == 1) mxp = mxv[i];}    cout << "! " << min(mxp, mnp) + 1 << " " << max(mxp, mnp) << endl;return 0;
}
http://www.rkmt.cn/news/16847.html

相关文章:

  • RK3588和FPGA桥片之间IO电平信号概率性不能通信原因 - 实践
  • 蒟蒻的第一篇随笔
  • oppoR9m刷Linux系统: 安装MTK USB VCOM驱动
  • 可视化大屏工具对比:GoView、DataRoom、积木JimuBI、Metabase、DataEase、Apache Superset 与 Grafana - 实践
  • [特殊字符] FFmpeg 学习笔记 - 详解
  • .NET周刊【9月第3期 2025-09-21】
  • 2025教练技术行业深度剖析:目标人群、费用与品牌选择
  • 免费开源Umi-OCR,离线采用,批量精准!
  • STM32外部中断(EXTI)以及旋转编码器的简介 - 指南
  • 神经网络中的梯度消失与梯度爆炸 - 实践
  • 基于 Chrome 浏览器扩展的Chroma简易图形化界面 - 实践
  • 详细介绍:go语言学习 第4章:流程控制
  • 《一元微积分》讲义习题
  • 开源量子模拟引擎:Quantum ESPRESSO本地部署教程,第一性原理计算轻松入门! - 实践
  • 详细介绍:QT常用控件(1)
  • 题解:P4779 【模板】单源最短路径(标准版)
  • 网关配置
  • 完整教程:docker创建postgreSql带多个init的sql
  • vscode的文心快码插件不错
  • 股市技术分析突破
  • 34.1STM32下的can总线实现知识(区分linux)_csdn - 详解
  • webpack和vite的区别 - 指南
  • 校招题
  • go语言学习 第5章:函数 - 详解
  • 实用指南:Hive SQL 中 BY 系列关键字全解析:从排序、分发到分组的核心用法
  • 改写自己的浏览器插件工具 myChromeTools - 详解
  • 通过litestream 进行sqlite-vec 数据备份以及恢复
  • 对于路由使用的ref的疑问
  • 钱璐璐,唯一通讯发Nature,作者仅2人!
  • # Redis vs ElasticSearch 搜索性能对比