loj2985「WC2019」I 君的商店(二分,思维)

loj

Luogu

题解时间

真的有点猛的思维题。

首先有一个十分简单的思路:

花费 $ 2N $ 确定一个为 $ 1 $ 的数。

之后每次随机选择一对没有确定的数 $ x,y $ 与 $ 1 $ 比较,再将 $ x,y $ 相互比较,总能确定其中一个数的值。

这样是 $ 7N $ 。

而另一方面,这道题也是正解来自部分分。

考虑子任务3:

很明显首先一次比较确定是先0后1还是先1后0,

之后二分确定分界的位置即可,花费是 $ 3logN $ 。

观察正解数据范围,正好是 $ 5N+3logN $ 。

考虑能不能向上面的子任务转化。

我们发现 $ 7N $ 暴力仅使用后 $ 5N $ 的操作依然可以确定为0的数,最终留下一个0000......11111的序列,进而得解。

具体实现比较复杂。

#include<bits/stdc++.h>
// #include"shop.h"
using namespace std;
typedef long long lint;
int query(int *S, int nS, int *T, int nT);
int lst1[2],lst2[2];
int sta[100011],stp;
int cmp(const int &a,const int &b){lst1[0]=a,lst2[0]=b;return query(lst1,1,lst2,1);}
int cmp(const int &a,const int &b,const int &c){lst1[0]=a,lst1[1]=b,lst2[0]=c;return query(lst1,2,lst2,1);}
void fix(int &a,int &b){if(!cmp(a,b)) swap(a,b);}
void ThirdAvenue(int task_id,int n,int K,int ans[])
{
int l=0,r=0,mid=0,k=0;
if(cmp(0,n-1))
{
l=0,r=n-2;while(l<=r){mid=l+r>>1;cmp(mid,mid+1,n-1)?(k=mid+1,l=mid+1):(r=mid-1);}
for(int i=0;i<k;i++) ans[i]=0;for(int i=k+1;i<n;i++) ans[i]=1;
ans[k]=K^((n-1-k)&1);
}else
{
l=1,r=n-1;while(l<=r){mid=l+r>>1;cmp(mid-1,mid,0)?(r=mid-1):(k=mid,l=mid+1);}
for(int i=0;i<k;i++) ans[i]=1;for(int i=k+1;i<n;i++) ans[i]=0;
ans[k]=K^(k&1);
}
}
void EnergySynergyMatrix(int task_id,int n,int K,int ans[])
{
int x=0,y=1;for(int i=2,z=i;i<n;i++,z=i)
{
fix(x,z);if(cmp(x,z,y)) ans[x]=0,swap(x,z);
else sta[stp++]=y,swap(y,z);
}fix(x,y),ans[y]=1;if(!stp){ans[x]=K^1;return;}sta[stp++]=y;
int l=0,r=stp-2,mid=0,k=0;while(l<=r){mid=l+r>>1;cmp(sta[mid],sta[mid+1],y)?(k=mid+1,l=mid+1):(r=mid-1);}
for(int i=0;i<k;i++) ans[sta[i]]=0;for(int i=k+1;i<stp;i++) ans[sta[i]]=1;
int z=sta[k];fix(x,z);
if(cmp(x,z,y)) ans[x]=0,ans[z]=K^((stp-1-k)&1);
else ans[x]=!(K^((stp-1-k)&1)),ans[z]=1;
}
void find_price(int task_id,int n,int K,int ans[])
{
if(task_id==3) return ThirdAvenue(task_id,n,K,ans);
else return EnergySynergyMatrix(task_id,n,K,ans);
}

loj2985「WC2019」I 君的商店(二分,思维)的更多相关文章

  1. 【LOJ】#2985. 「WC2019」I 君的商店

    LOJ#2985. 「WC2019」I 君的商店 一道很神仙的题啊QAQ 居然是智商题--不是乱搞或者是大数据 我们可以用2N问出一个最大值是1 然后对于任意两个值\(x + y\)和\(a\)比较 ...

  2. LOJ #2985. 「WC2019」I 君的商店

    传送门 搬题解QwQ 首先最大值一定为 \(1\),直接扫一遍两两比较 \(O(2N)\) 求出最大值 设最大值位置为 \(a\),对于任意两个没有确定的位置 \(x,y\) 询问 \([a,x+y] ...

  3. 【LOJ】#2983. 「WC2019」数树

    LOJ2983. 「WC2019」数树 task0 有\(i\)条边一样答案就是\(y^{n - i}\) task1 这里有个避免容斥的方法,如果有\(i\)条边重复我们要算的是\(y^{n - i ...

  4. loj3161「NOI2019」I 君的探险(随机化,整体二分)

    loj3161「NOI2019」I 君的探险(随机化,整体二分) loj Luogu 题解时间 对于 $ N \le 500 $ 的点,毫无疑问可以直接 $ O(n^2) $ 暴力询问解决. 考虑看起 ...

  5. 「ZJOI2018」胖(ST表+二分)

    「ZJOI2018」胖(ST表+二分) 不开 \(O_2\) 又没卡过去是种怎么体验... 这可能是 \(ZJOI2018\) 最简单的一题了...我都能 \(A\)... 首先我们发现这个奇怪的图每 ...

  6. LibreOJ #2006. 「SCOI2015」小凸玩矩阵 二分答案+二分匹配

    #2006. 「SCOI2015」小凸玩矩阵 内存限制:256 MiB时间限制:1000 ms标准输入输出 题目类型:传统评测方式:文本比较 上传者: 匿名 提交提交记录统计讨论测试数据   题目描述 ...

  7. 【loj2985】【WC2019】I君的商店

    题目 交互题: 有\(n\)个物品,每个物品的价格为0或者1; 给出为1的物品的个数奇偶性k,并保证至少有一个价格为1: 每次可以询问一个集合S的另一个集合T的价值和的大小,交互库会返回>=或者 ...

  8. LOJ#2983. 「WC2019」数树

    传送门 抄题解 \(Task0\),随便做一下,设 \(cnt\) 为相同的边的个数,输出 \(y^{n-cnt}\) \(Task1\),给定其中一棵树 设初始答案为 \(y^n\),首先可以发现, ...

  9. LOJ#2983. 「WC2019」数树 排列组合,生成函数,多项式,FFT

    原文链接www.cnblogs.com/zhouzhendong/p/LOJ2983.html 前言 我怎么什么都不会?贺忙指导博客才会做. 题解 我们分三个子问题考虑. 子问题0 将红蓝共有的边连接 ...

随机推荐

  1. Solution -「WC 2022」秃子酋长

    \(\mathscr{Description}\)   Link. (It's empty temporarily.)   给定排列 \(\{a_n\}\),\(q\) 次询问,每次给出 \([l,r ...

  2. Solution -「CF 1622F」Quadratic Set

    \(\mathscr{Description}\)   Link.   求 \(S\subseteq\{1,2,\dots,n\}\),使得 \(\prod_{i\in S}i\) 是完全平方数,并最 ...

  3. Solution -「NOI.AC 省选膜你赛」寄蒜几盒

    题目 题意简述   给定一个含有 \(n\) 个顶点的凸多边形( \(n\) 是偶数),对于每一对相对的边(即中间有 \(\frac{n}2-1\) 条其它边),延长它们以将平面分割为多块,并把包含原 ...

  4. Vue 源码解读(6)—— 实例方法

    前言 上一篇文章 Vue 源码解读(5)-- 全局 API 详细介绍了 Vue 的各个全局 API 的实现原理,本篇文章将会详细介绍各个实例方法的实现原理. 目标 深入理解以下实例方法的实现原理. v ...

  5. 渗透测试工程师认证 | CISP-PTE证书含金量

    注册渗透测试工程师(CISP-PTE)认证是由中国信息安全测评中心针对攻防专业领域实施的资质培训, 是国内唯一针对网络安全渗透测试专业人才的资格认证,是目前国内最为主流及被业界认可的专业攻防领域的资质 ...

  6. [数分笔记]用Dedekind切割定理证明确界定理

    1.定理内容 Dedekind切割定理:设是实数集的一个切割,则或者有最大数,或者有最小数. 确界定理:非空有上界的数集必有上确界,非空有下界的数集必有下确界. 2.证明过程 设非空数集有上界 记,即 ...

  7. PPPoE协议测试——网络测试仪实操

    前言: 与传统的接入方式相比,PPPoE具有较高的性能价格比,它在包括小区组网建设等一系列应用中被广泛采用,目前流行的宽带接入方式 ADSL 就使用了PPPoE协议. 随着低成本的宽带技术变得日益流行 ...

  8. 金融BI是什么?为什么金融同行都在讨论这个!

    最近,我和金融行业的几位朋友聚会,觥筹交错之间听到最多的竟然是「金融BI」这个词!这可触及到我的知识盲区了,到底什么是金融BI呢? 朋友向我解释:BI商业智能是一种提高企业智能化的手段和工具,既可以满 ...

  9. 能无缝嵌入Excel的报表工具,报表轻松做!

    现在很多人做数据分析会被推荐选择去用编程R和Python.PowerBI.Tableau.Qlik.Smartbi... 从目前数据分析的行业来说,Excel是世界上使用人数最多的报表分析工具,没有之 ...

  10. Linux添加永久路由的方法

    通常我们使用route add -net添加临时路由.当系统重启,临时路由将丢失,重新配置路由带来了不必要的麻烦.可通过固化临时路由为永久路由的方法解决该问题. static-routes文件为路由固 ...