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);
}

最新文章

  1. Spring:源码解读Spring IOC原理
  2. Javascript的setTimeOut()和setInterval()的定时器用法
  3. URL中文转码问题
  4. 数据库执行监控,除了Profiler的方案
  5. Java Garbage Collection/垃圾收集 策略查看
  6. 谈谈JPA-04-JPA的常用API
  7. seleniu IDE 点点滴滴
  8. 详谈easyui datagrid增删改查操作
  9. Android_Studio 及SDK下载
  10. PAT1012:The Best Rank
  11. java集合(list,set,map)
  12. JavaScript数组方法--includes、indexOf、lastIndexOf
  13. (后端)sql手工注入语句&amp;SQL手工注入大全(转)
  14. C#调用endtask
  15. jq demo 轮播图,图片可调用,向上,自动+鼠标点击切换
  16. iOS动画-从UIView到Core Animation
  17. request 的下载文件
  18. requestAnimationFrame 知识点
  19. python - requests中添加配置文件
  20. C# 模拟网站登陆

热门文章

  1. C++ 反汇编:关于函数调用约定
  2. Solution -「ARC 104C」Fair Elevator
  3. .NET 7 预览版 1 发布
  4. 一、Mybatis初体验
  5. nginx负载均衡中利用redis解决session一致性问题
  6. Cesium 加载地形数据
  7. java操作excel(通过POI)
  8. 攻防世界--神奇的Modbus
  9. Wireshark教程之过滤器设置
  10. 【C#设计模式】里氏替换原则