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的console你知道多少

    js的console你知道多少? 列出所有的console属性 console.dir(console) 或者 console.dirxml(console) 记录代码执行时间 console.tim ...

  2. 4.Django使用celery

    1. 配置celery   创建django项目celery_demo, 创建应用demo: django-admin startproject celery_demo python manage.p ...

  3. HTML篇

    要内容 web标准 浏览器介绍 开发工具介绍 HTML介绍 HTML颜色介绍 HTML规范 HTML结构详解 一.web标准 web准备介绍: w3c:万维网联盟组织,用来制定web标准的机构(组织) ...

  4. delphi 原生 ADODB.recordset

    ADODB.recordset ..\source\rtl\win\Winapi.ADOInt.pas..\17.0\OCX\Servers\ADODB2010.pasCLASS_Recordset: ...

  5. minerd.exe 处理

    :top TASKKILL /F /IM "minerd.exe" Goto top and then searching the file system for minerd.e ...

  6. C++深度解析教程学习笔记(5)面向对象

    1. 面向对象基本概念 (1)面向对象的意义在于 ①将日常生活中习惯的思维方式引入程序设计中 ②将需求中的概念直观的映射到解决方案中 ③以模块为中心构建可复用的软件系统 ④提高软件产品的可维护性和可扩 ...

  7. Java多线程-新特征-阻塞栈LinkedBlockingDeque

    对于阻塞栈,与阻塞队列相似.不同点在于栈是“后入先出”的结构,每次操作的是栈顶,而队列是“先进先出”的结构,每次操作的是队列头. 这里要特别说明一点的是,阻塞栈是Java6的新特征.. Java为阻塞 ...

  8. CRM客户关系管理系统知识点总结

    一.项目需求(使用PrecessOn) 二.models.py from django.db import models from django.contrib.auth.models import ...

  9. Spring总结五:小结 使用spring访问servlet

    使用spring访问servlet 首先先建一个web项目,并在pom.xml中引入依赖包:spring-context和jsp servlet相关包,以及tomcat插件 其次建一个spring的配 ...

  10. 【bzoj3942】[Usaco2015 Feb]Censoring

    [题目大意] 有一个S串和一个T串,长度均小于1,000,000,设当前串为U串,然后从前往后枚举S串一个字符一个字符往U串里添加,若U串后缀为T,则去掉这个后缀继续流程. [样例输入] whatth ...