Atcoder 题面传送门 & 洛谷题面传送门

u1s1 Atcoder 不少思维题是真的想不出来,尽管在 Atcoder 上难度并不高

二分答案(这我倒是想到了),检验最上面一层的数是否 \(\ge x\)。

我们将最底下一层的数中 \(\ge x\) 的 \(a_i\) 设为 \(1\),\(<x\) 的设为 \(0\),那么原题可以转化为每次操作对于相邻三个数,如果 \(1\) 的个数 \(\ge 2\),就在该位上填一个 \(1\),否则在该位上填一个 \(0\),求最终顶上的数是 \(0\) 还是 \(1\)。

不难发现经过二分答案这个转化,我们将原来值域在 \([1,2n-1]\) 范围内的问题缩小为值域在 \([0,1]\) 范围内的问题,可直接做似乎还是有些棘手,我们不妨进一步探究这里面的规律。

我们手玩几组数据即可发现一个性质,如果相邻两个数都是 \(1\),那么它上面所有数都是 \(1\),反正如果相邻两个数都是 \(0\),那么它上面所有数都是 \(0\),并且如果 \(i\) 满足 \(a_{i}=a_{i+1}=a_{i-2}=1\),那么到了上一层第 \(i-1\) 列也会变成 \(1\),可以看作这个 \(1\) “蔓延”到了第 \(i-1\) 列,于是我们猜测,第 \(n\) 层的数一定与距离中心点最近的 \(a_{i}=a_{i+1}\) 的 \(i\) 有关,因为它能最快“蔓延”到第 \(n\) 列。

事实果真如此。

这里稍微证明一下。记 \(i=n+p\) 为距离中心点最近的满足 \(a_i=a_{i+1}\) 的 \(i\),其中 \(p\ge 0\)(\(p<0\) 也同理,翻转一下就行了),如果 \(p=0\) 那显然根据之前的结论,第 \(n\) 列的数就是 \(a_n\),符合题意。否则,由于 \(i=n+p\) 为最近的满足 \(a_i=a_{i+1}\) 的 \(i\),必然有 \([n-p,n+p]\) 部分的 \(a_i\) 为 \(01\) 间隔分布,即 \(a_{n+p-2}=a_{n+p-4}=a_{n+p-6}=\cdots=a_{n-p+2}=a_{n-p}=a_{n+p}\),\(a_{n+p-1}=a_{n+p-3}=a_{n+p-5}=\cdots=a_{n-p+1}=1-a_{n+p}\),由 \(a_{n+p-2}=a_{n+p}=a_{n+p+1}\) 可知从下往上数第二行第 \(n+p-1\) 位置上的值也是 \(a_{n+p}\),相当于 \(a_{n+p}\) 向左蔓延了一格。而显然对于 \(01\) 分布的序列,进行一遍取中位数操作之后还是 \(01\) 间隔分布的,因此到第二行可以看作 \(p'=p-1\) 的版本继续递归下去,归纳可得最终的数就是 \(a_{n+p}\)。

有人可能会问:如果存在 \(p\) 使得 \(i=n+p\) 为距离中心点最近的满足 \(a_i=a_{i+1}\) 的 \(i\),满足 \(a_{n+p}=a_{n+p+1}\ne a_{n-p}=a_{n-p-1}\) 怎么办呢?稍微动点脑子即可知道这种情况是不可能的,因为根据上面的证明过程可知 \([n-p,n+p]\) 是 \(01\) 间隔分布的,因此 \(\forall x,y\in[n-p,n+p]\),若 \(|x-y|\) 为偶数,则 \(a_x=a_y\),反之 \(a_x\ne a_y\),而 \(n-p\equiv n+p\pmod{2}\),故 \(a_{n-p}=a_{n+p}\),因此不会出现这种情况。

最后特判整个 \(a\) 数组就是 \(01\) 间隔分布的情况,此时最上面一层的数就是 \(a_{2n-1}\)。

const int MAXN=1e5;
int n,a[MAXN*2+5],b[MAXN*2+5];
bool check(int x){
for(int i=1;i<(n<<1);i++) b[i]=(a[i]>=x);
for(int i=0;i<n-1;i++){
if(b[n+i]==b[n+i+1]) return b[n+i];
if(b[n-i]==b[n-i-1]) return b[n-i];
} return b[1];
}
int main(){
scanf("%d",&n);
for(int i=1;i<(n<<1);i++) scanf("%d",&a[i]);
int l=1,r=(n<<1)-1,mid,x=-114514;
while(l<=r) (check(mid=l+r>>1))?(x=mid,l=mid+1):(r=mid-1);
printf("%d\n",x);return 0;
}

Atcoder Grand Contest 006 D - Median Pyramid Hard(二分+思维)的更多相关文章

  1. AtCoder Grand Contest 006

    AtCoder Grand Contest 006 吐槽 这套题要改个名字,叫神仙结论题大赛 A - Prefix and Suffix 翻译 给定两个串,求满足前缀是\(S\),后缀是\(T\),并 ...

  2. AtCoder Grand Contest 019 B - Reverse and Compare【思维】

    AtCoder Grand Contest 019 B - Reverse and Compare 题意:给定字符串,可以选定任意i.j且i<=j(当然i==j时没啥卵用),然后翻转i到j的字符 ...

  3. AtCoder Grand Contest 006 C:Rabbit Exercise

    题目传送门:https://agc006.contest.atcoder.jp/tasks/agc006_c 题目翻译 数轴上有\(N\)只兔子,从\(1\)到\(N\)编号,每只兔子初始位置是\(x ...

  4. Atcoder Grand Contest 022 E - Median Replace(dp)

    Atcoder 题面传送门 & 洛谷题面传送门 首先考虑对于固定的 01 串怎样计算它是否可以通过将三个连续的 \(0\) 或 \(1\) 替换为其中位数得到.我们考虑单调栈,新建一个栈,栈底 ...

  5. AtCoder Grand Contest 006 (AGC006) C - Rabbit Exercise 概率期望

    原文链接https://www.cnblogs.com/zhouzhendong/p/AGC006C.html 题目传送门 - AGC006C 题意 有 $n$ 个兔子,从 $1$ 到 $n$ 编号, ...

  6. AtCoder Grand Contest 006 F - Blackout

    Description 在 \(n*n\) 的棋盘上给出 \(m\) 个黑点,若 \((x,y)\),\((y,z)\) 都是黑点,那么 \((z,x)\) 也会变成黑点,求最后黑点的数量 题面 So ...

  7. [Atcoder Grand Contest 006 F][AGC006F] Blackout [染色]

    题面 传送门 思路 首先,这个涂黑的方法我们来优化一下模型(毕竟当前这个放到矩形里面,你并看不出来什么规律qwq) 我们令每个行/列编号为一个点,令边(x,y)表示一条从x到y的有向边 那么显然只要有 ...

  8. AtCoder Grand Contest 006 题解

    传送门 \(A\) 咕咕 const int N=105; char s[N],t[N];int n; inline bool eq(R int k){fp(i,1,k)if(s[n-k+i]!=t[ ...

  9. Atcoder Grand Contest 005 E - Sugigma: The Showdown(思维题)

    洛谷题面传送门 & Atcoder 题面传送门 记先手移动棋子的树为红树,后手移动棋子的树为蓝树. 首先考虑一个性质,就是如果与当前红色棋子所在的点相连的边中存在一条边,满足这条边的两个端点在 ...

随机推荐

  1. 初识HTML01

    什么是页面? 页面是基于浏览器的应用程序 页面是数据展示的载体,由浏览器和服务器共同执行产物. 浏览器的功能 向服务器发送用户请求指令 接收并解析数据展示给用户 服务器的功能 存储页面资源 处理并响应 ...

  2. Java中的函数式编程(四)方法引用method reference

    写在前面 我们已经知道,lambda表达式是一个匿名函数,可以用lambda表达式来实现一个函数式接口.   很自然的,我们会想到类的方法也是函数,本质上和lambda表达式是一样的,那是否也可以用类 ...

  3. 写了10000条Airtest截图脚本总结出来的截图经验,赶紧收藏!

    前言 今天想先给大家分享1个小白用户的Airtest从入门到放弃的故事: 小A是一个自动化的小白,在逛测试论坛的时候,偶然间发现了Airtest这个基于图像识别的UI自动化框架. 出于好奇,小A试用了 ...

  4. Java:ThreadLocal小记

    Java:ThreadLocal小记 说明:这是看了 bilibili 上 黑马程序员 的课程 java基础教程由浅入深全面解析threadlocal 后做的笔记 内容 ThreadLocal 介绍 ...

  5. 航胥:北航教务助手——Beta阶段发布声明

    下载地址在文章末尾! 这里是"航胥",一款更想要了解你的北航教务助手 Beta阶段,我们进化了! Beta阶段我们的新功能有: 课程评价功能 所有用户选过的课程都会在课程评价页面进 ...

  6. Scrum Meeting 14

    第14次例会报告 日期:2021年06月07日 会议主要内容概述: 汇报了已完成的工作,明确了下一步目标,正在努力赶进度. 一.进度情况 我们采用日报的形式记录每个人的具体进度,链接Home · Wi ...

  7. [Beta]the Agiles Scrum Meeting 3

    会议时间:2020.5.14 20:00 1.每个人的工作 今天已完成的工作 成员 已完成的工作 yjy 实现前端界面美化 tq 实现查看.删除测试点功能的前端修复功能中的bug wjx 升级系统实现 ...

  8. Envoy实现.NET架构的网关(三)代理GRPC

    什么是GRPC gRPC是一种与语言无关的高性能远程过程调用 (RPC) 框架.gRPC 的主要好处是: 现代.高性能.轻量级的 RPC 框架. 契约优先的 API 开发,默认使用协议缓冲区,与语言无 ...

  9. hdu 3635 Dragon Balls(并查集)

    题意: N个城市,每个城市有一个龙珠. 两个操作: 1.T A B:A城市的所有龙珠转移到B城市. 2.Q A:输出第A颗龙珠所在的城市,这个城市里所有的龙珠个数,第A颗龙珠总共到目前为止被转移了多少 ...

  10. iptables 原理及应用

    转自:iptables 原理及应用 iptables是一个Linux下优秀的nat+防火墙工具,我使用该工具以较低配置的传统pc配置了一个灵活强劲的防火墙+nat系统,小有心得,看了网上也有很多这方面 ...