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

Codeforces Round 1063 (Div. 2) 补题记录

Codeforces Round 1063 (Div. 2) 补题记录

D - Diadrash

题目大意:

本题为交互题,存在一个 \([0, \ n - 1]\) 的排列 \(p\),以及 \(q\) 个区间。

每次询问 "\(? \ l \ r\)" 会返回区间 \([l, \ r]\)\(Mex\),最多可以询问 \(30\) 次。

问这 \(q\) 个区间的最大 \(Mex\) 为多少。

思路:

首先我们可以发现两个性质:

  • \(A = [l, \ r], B = [L, \ R]\),若 \(A\)\(B\) 所包含,则 \(Mex(A) \leq Mex(B)\)

  • \(Mex(L, \ R) = min(min(p_1, \dots, p_{L-1}), min(p_{R+1}, \dots, p_n))\)

首先我们可以利用第一个性质减少区间的数量。而对于第二个性质,我们可以得到 \(Mex([L, \ R]) = min(Mex([L, \ n]), Mex([1, \ R]))\)。证明如下:

  • \(A(L) = Mex([L, \ n]), \ B(R) = Mex([1, \ R])\)

  • 由性质二可得:\(A(L) = min(p_1, \dots, p_{L - 1}), \ B(R) = min(p_{R + 1}, \dots, p_n)\)

  • \(Mex([L, \ R]) = min(A(L), B(R))\)

然后我们设 \(f(i) = Mex([L_i, \ R_i]) = min(A(L_i), B(R_i))\)。那么有:

\[f(i) = \begin{cases} A(L_i), \ A(L_i) > B(R_i) \\ \\ B(R_i), \ A(L_i) \leq B(R_i) \end{cases} \]

通过对区间排序,可以使得当 \(i\) 增大时,\(L_i\)\(R_i\) 都是单调不减的。对于 \(A(L_i)\),当 \(i\) 增大时,\(L_i\) 增大,\([L_i, \ n]\) 所覆盖区间缩小,因此\(A(L_i)\) 要么不变要么减小;而对于 \(B(R_i)\),当 \(i\) 增大时,\(R_i\) 增大,\([1, \ R_i]\) 所覆盖区间扩大,因此\(B(R_i)\) 要么不变要么增大。

因此,我们对所有区间用二分模拟三分的方法,当 \(f(i) = A(L_i)\) 时,缩小 \(i\),当 \(f(i) = B(R_i)\) 时,增大 \(i\),同时更新答案即可。

code:

#include <bits/stdc++.h>
using namespace std;// #define endl '\n'
#define i64 long longvoid MuBai() {int n, q;cin >> n >> q;vector<pair<int, int>> range(q), merged;for (int i = 0; i < q; i ++ ) {cin >> range[i].first >> range[i].second;}ranges::sort(range, [&](auto A, auto B) {if (A.first == B.first) return A.second > B.second;return A.first < B.first;});int maxRight = -1;for (int i = 0; i < q; i ++ ) {if (range[i].second > maxRight) {merged.emplace_back(range[i]);maxRight = range[i].second;}}function<int(int, int)> ask = [&](int l, int r) {int res = 0;cout << "? " << l << ' ' << r << endl;cin >> res;return res;};int l = 1, r = merged.size(), ans = -1;while (l <= r) {int mid = (l + r) >> 1;int left = merged[mid - 1].first;int right = merged[mid - 1].second;int A = ask(left, n), B = ask(1, right);ans = max(ans, min(A, B));if (A > B) l = mid + 1;else r = mid - 1;}cout << "! " << ans << endl;
}int main() {// ios::sync_with_stdio(false);// cin.tie(nullptr), cout.tie(nullptr);int t; cin >> t;while (t -- ) MuBai();return 0;
}// 0 3 1 2
// 3 5 0 1 4 2
// 0 1 2 3
http://www.jsqmd.com/news/54150/

相关文章:

  • 2025最新宠物抓伤急救液品牌怎么选?葆爱堂专注宠物健康,宠物抓伤创面消毒液/宠物消杀,更专业,更安全
  • 从纸杯机到纸盘机!2025 全品类制杯机选购指南:全伺服 / 超声波款 + 纸碗机 / 纸盖机省本技巧
  • 2025最新宠物抓伤应急护理液品牌推荐!宠物抓伤消毒液/宠物消杀/宠物抓伤创面消毒液,专业宠物消杀品权威榜单发布及选择指南,守护爱宠与家人健康
  • 【IEEE出版 | EI检索】第七届国际科技创新学术交流大会暨新能源科学与电力工程国际学术会议(NESEE 2025)
  • DNNRegression(pytorch)
  • 大模型开发技巧记录(不定期更新)
  • 2025年字节跳动奖学金揭晓:20位获奖人才研究方向速览
  • 2025最新宠物抓伤应急护理液品牌推荐!宠物抓伤消毒液/宠物消杀品/宠物抓伤创面消毒液,专业宠物消杀品权威榜单发布,守护健康安全
  • CoaXPress 相机采集卡对比 - Hello
  • Python+Selenium+PO设计模式实战指南
  • 2025年PC砖批发厂家权威推荐榜单:地铺石/仿石材砖‌/石材‌源头厂家精选
  • 2025建材推荐榜:煌匠美缝剂_环氧地坪_彩砂自流平,装修选材必看!
  • 数据泄露已成为现实威胁,你的Salesforce安全做好了吗?
  • 【IEEE出版 | EI检索】第七届国际科技创新学术交流大会暨信息技术与计算机应用学术会议(ITCA 2025)
  • 实用指南:LSTM模型做二分类(PyTorch实现)
  • 河南煌匠建材:专注美缝剂、环氧地坪、彩砂自流平,15年匠心守护优质空间 (2)
  • 6款免费AI毕业论文工具推荐:一键生成+零成本降重,效率翻倍
  • 打开文件夹
  • 2025年11月SEM扫描电镜厂家推荐榜:进口/国产/日立/国仪/钨灯丝/FIB/日立冷场/电子/场发射/高分子/超高分辨率/扫描电镜品牌综合参考指南,上海富泰微——微观视界的硬核担当
  • 玩 Linux 随便记录点东西
  • 占有率最高的工业总线:PROFINET、Modbus 与 EtherCAT
  • 2025年11月深圳网站建设公司TOP榜:知名网站建售/外贸网站建设公司后保障双维度解析
  • 如何判断一个痛点是结构性痛点(值得做生意)还是噪音(不要理会)?
  • 2025年广东家装全屋定制推广权威推荐榜单:广东全屋家具定制/广东全屋整装家具定制/广东全屋定制柜子供货商精选
  • 一文通关天文物理顶刊
  • 企业智能ITR升级指南:客户服务体系的实践思考
  • 【IEEE出版 | EI检索】第七届国际科技创新学术交流大会暨通信、信息系统和软件工程学术会议(CISSE 2025)
  • 机器学习在医疗领域的创新应用
  • 大带宽服务器租用建站有哪些优势
  • 隐私代币逆势上涨背后的技术、监管与市场博弈