Description

​ 现在有一个NN层的方块金字塔,从最顶层到最底层分别标号为1...N1...N。

​ 第ii层恰好有2i−12i−1个方块,且每一层的中心都是对齐的。

这是一个N=4N=4的方块金字塔

​ 现在,我们首先在最底层填入一个2N−12N−1的排列。之后,我们从i−1i−1层开始,逐步向上填入每一层的数。

​ 对于第ii(1≤i<N1≤i<N)层中位置为xx的方块,它的值为左下方、正下方和右下方的三个数的中位数。形式化地描述,就是i+1i+1层中x−1x−1、xx和x+1x+1三个位置的中位数。

​ 给定一个NN和长度为2N−12N−1的排列,请还原出最顶层唯一一个方块中的数值。

​ 下图就是一个还原的例子:

Input

​ 第一行一个正整数NN(2≤N≤1052≤N≤105)

​ 接下来一行有2N−12N−1个正整数a1,a2,...,a2N−1a1,a2,...,a2N−1,表示最底层的填数情况。保证aa是个排列。

Output

​ 只有一个正整数,表示最顶层那唯一一个格子里的数。

Sample Input

#Sample Input 1
4
1 6 3 7 4 5 2 #Sample Input 2
2
1 2 3

Sample Output

#Sample Output 1
4 #Sample Output 2
2

Sol

直接做显然是T的,我们考虑二分答案,二分之后把大于mid的置为1,其他置为0,然后从中间往两边判断,先出现俩连续0说明这个状态可行,否则不可行,如果没有连续数字的话直接判断第一位即可。

原因:两个连续相同的数字可以一直延伸到起点,而且水平距离近的优先。

Code

#include <cstdio>
int a[200005],n,ans;
bool dn(int x,int y,int z){return a[x]<=z&&a[y]<=z;}
bool up(int x,int y,int z){return a[x]>z&&a[y]>z;}
bool chk(int k)
{
for(int i=0;i<n-1;i++)
{
if(up(n-i,n-i-1,k)||up(n+i,n+i+1,k)) return 0;
if(dn(n-i,n-i-1,k)||dn(n+i,n+i+1,k)) return 1;
}
return dn(1,1,k);
}
int main()
{
scanf("%d",&n);
for(int i=1;i<n*2;i++) scanf("%d",&a[i]);
for(int l=0,r=2*n-1,mid=(l+r)>>1;l<=r;mid=(l+r)>>1) if(chk(mid)) r=mid-1,ans=mid;else l=mid+1;
printf("%d\n",ans);
}

[AGC006] D - Median Pyramid Hard 二分的更多相关文章

  1. AT2165 Median Pyramid Hard 二分答案 脑洞题

    无论再来多少次也不可能想到的写法. 二分一个最小的顶端值\(k\),大于设为\(1\)小于等于设为\(0\),可以证猜出来(你跟我说这可以?)如果存在两个连在一起的0/1那么它们会一直往上跑,还可以很 ...

  2. B - Median Pyramid Easy 构造题

    B - Median Pyramid Easy Time limit : 2sec / Memory limit : 256MB Score : 400 points Problem Statemen ...

  3. 【AtCoder】【模型转化】【二分答案】Median Pyramid Hard(AGC006)

    题意: 给你一个排列,有2*n-1个元素,现在进行以下的操作: 每一次将a[i]替换成为a[i-1],a[i],a[i+1]三个数的中位数,并且所有的操作是同时进行的,也就是说这一次用于计算的a[], ...

  4. Atcoder Grand Contest 006 D - Median Pyramid Hard(二分+思维)

    Atcoder 题面传送门 & 洛谷题面传送门 u1s1 Atcoder 不少思维题是真的想不出来,尽管在 Atcoder 上难度并不高 二分答案(这我倒是想到了),检验最上面一层的数是否 \ ...

  5. hdu 5432 Pyramid Split 二分

    Pyramid Split Time Limit: 1 Sec Memory Limit: 256 MB 题目连接 http://bestcoder.hdu.edu.cn/contests/conte ...

  6. AtCoder - 4351 Median of Medians(二分+线段树求顺序对)

    D - Median of Medians Time limit : 2sec / Memory limit : 1024MB Score : 700 pointsProblem Statement ...

  7. AtCoder Regular Contest 101 (ARC101) D - Median of Medians 二分答案 树状数组

    原文链接https://www.cnblogs.com/zhouzhendong/p/ARC101D.html 题目传送门 - ARC101D 题意 给定一个序列 A . 定义一个序列 A 的中位数为 ...

  8. AGC006D Median Pyramid Hard

    闲扯 今天模拟的题,应该是挺简单的二分和贪心,就是没想出来,我好弱啊 顺便ORZ聚聚BLUESKY007,踩爆我了 思路 今天发现中位数性质如此优秀 二分最后塔顶的数,大于等于它的数变为1,小于它的数 ...

  9. Median(vector+二分)

    Median Time Limit: 5 Seconds Memory Limit: 65536 KB The median of m numbers is after sorting them in ...

随机推荐

  1. js 鼠标点击文本框 提示文字消失

    onfocus="if(this.value==defaultValue) {this.value='';}" onblur="if(!value) {value=def ...

  2. javascript原型继承中的两种方法对比

    在实际的项目中,我们通常都是用构造函数来创建一个对象,再将一些常用的方法添加到其原型对象上.最后要么直接实例化该对象,要么将它作为父类,再申明一个对象,继承该父类. 而在继承的时候有两种常用方式,今天 ...

  3. Hibernate XXX.hbm.xml 里的class标签的 schema 属性解释

    转自:https://blog.csdn.net/mym43210/article/details/30230173 1 <?xml version="1.0" encodi ...

  4. mysql 批量插入与单条插入 的效率比较

    1.数据插入性能(单个插入和批量插入) public class Test { private Long id; private String test; public Long getId() { ...

  5. 外网访问vmvare

    使用端口映射即可,以tplink wr886n为例, 方法如下: 1.打开浏览器,输入默认ip192.168.0.1回车登录: 2.登录对话框,输入 密码点击确定: 3.点击转发规则--虚拟服务器,点 ...

  6. java基础篇之HashMap

    HashMap和C#中的Dictionary基本一样 键是唯一值 值可以是对象 循环HashMap的方式:一: 1,通过Set<T> st = hs.keySet()找到所有的key值集合 ...

  7. Linux Resin4.0 安装配置

    Resin,是一个非常流行的application server,对servlet和JSP提供了良好的支持,性能优良,resin自身采用Java语言开发.Resin Pro版本支持缓存和负载均衡,收费 ...

  8. mysql中如何不重复插入满足某些条件的重复的记录的问题

    最近在项目中遇到了这样的一个问题“: 在mysql数据库中需要每次插入的时候不能插入三个字段都相同的记录.在这里使用到了 insert into if not exists  和insert igno ...

  9. 张超超OC基础回顾03_结构体类型作为成员变量的特殊用法

    直接上例子: 要求: 合理的设计一个”学生“类 学生有* 姓名* 生日两个属性和说出自己姓名生日方法  要求利用设计的学生类创建学生对象,并说出自己的姓名和年龄 描述学生类 事物名称: 学生(Stud ...

  10. HighCharts SVN IReport进行PDF报表设计--模板

    BOS物流项目笔记第十五天 HIghcharts是很强大的图表绘制插件,它是基于纯js绘制的.当然地,对于图表也会有很多操作了.下面就我工作时遇到的一些比较常见的highcharts的操作进行小结,不 ...