题目链接:http://61.187.179.132/JudgeOnline/problem.php?id=1941

题意:给出平面上n个点,找出一点p,使得距离p最近和最远的点的距离之差最小。输出这个差值。

思路: 计算出距离每个点最近的点的距离和最远点的的距离。怎么计算呢?首先我们计算每个点到其左下角的那些点的最近最远距离。只要按照x升序然后y升序,之后将y离散化。一个一个插入到树状数组中。这样的话(x2+y2)-(x1+y1)的差值就是它们的距离。对于其右下角、左上角、右上角乘以(-1,1)(1,-1)(-1,-1)就跟处理左下角一样了。

struct node
{
    int x,y,id;
};

node a[N];
int S[2][N],y[N];
int n,f[N][2];

void add(int flag,int x,int t)
{
    while(x<N) 
    {
        if(!flag) upMin(S[flag][x],t),x+=x&-x;
        else upMax(S[flag][x],t),x+=x&-x;
    }
}

int get(int flag,int x)
{
    int ans;
    if(!flag)
    {
        ans=INF;
        while(x) upMin(ans,S[flag][x]),x-=x&-x;
    }
    else
    {
        ans=-INF;
        while(x) upMax(ans,S[flag][x]),x-=x&-x;
    }
    return ans;
}

int cmp(node a,node b)
{
    if(a.x!=b.x) return a.x<b.x;
    return a.y<b.y;
}

void deal(int sx,int sy)
{
    int i;
    FOR1(i,n)
    {
        a[i].x*=sx;
        a[i].y*=sy;
        y[i]=a[i].y;
    }
    sort(y+1,y+n+1);
    sort(a+1,a+n+1,cmp);
    FOR1(i,N-1) S[1][i]=-INF,S[0][i]=INF;
    int p,k;
    FOR1(i,n)
    {
        p=lower_bound(y+1,y+n+1,a[i].y)-y;
        k=a[i].id;
        upMin(f[k][0],a[i].x+a[i].y-get(1,p));
        upMax(f[k][1],a[i].x+a[i].y-get(0,p));
        add(1,p,a[i].x+a[i].y);
        add(0,p,a[i].x+a[i].y);
    }
    FOR1(i,n)
    {
        a[i].x*=sx;
        a[i].y*=sy;
    }
}

int main()
{
    RD(n);
    int i;
    FOR1(i,n) RD(a[i].x,a[i].y),a[i].id=i;
    FOR1(i,n) f[i][0]=INF,f[i][1]=-INF;
    deal(1,1); deal(1,-1); deal(-1,1); deal(-1,-1);
    int ans=INF;
    FOR1(i,n) upMin(ans,f[i][1]-f[i][0]);
    PR(ans);
}

HDU 1941 Hide and Seek(离散化+树状数组)的更多相关文章

  1. HDU 6318 - Swaps and Inversions - [离散化+树状数组求逆序数][杭电2018多校赛2]

    题目连接:http://acm.hdu.edu.cn/showproblem.php?pid=6318 Problem Description Long long ago, there was an ...

  2. HDU 5792 World is Exploding (离散化+树状数组)

    题意:给定 n 个数,让你数出 a < b && c < d && a != b != c != d  && Aa < Ab & ...

  3. hdu 3030 Increasing Speed Limits (离散化+树状数组+DP思想)

    Increasing Speed Limits Time Limit: 2000/10000 MS (Java/Others)    Memory Limit: 32768/32768 K (Java ...

  4. HDU 5862 Counting Intersections(离散化 + 树状数组)

    Counting Intersections Time Limit: 12000/6000 MS (Java/Others)    Memory Limit: 65536/65536 K (Java/ ...

  5. HDU 5862 Counting Intersections(离散化+树状数组)

    HDU 5862 Counting Intersections(离散化+树状数组) 题目链接http://acm.split.hdu.edu.cn/showproblem.php?pid=5862 D ...

  6. hdu 3015 Disharmony Trees (离散化+树状数组)

    Disharmony Trees Time Limit: 2000/1000 MS (Java/Others)    Memory Limit: 32768/32768 K (Java/Others) ...

  7. HDU 6318.Swaps and Inversions-求逆序对-线段树 or 归并排序 or 离散化+树状数组 (2018 Multi-University Training Contest 2 1010)

    6318.Swaps and Inversions 这个题就是找逆序对,然后逆序对数*min(x,y)就可以了. 官方题解:注意到逆序对=交换相邻需要交换的次数,那么输出 逆序对个数 即可. 求逆序对 ...

  8. CodeForces 540E - Infinite Inversions(离散化+树状数组)

    花了近5个小时,改的乱七八糟,终于A了. 一个无限数列,1,2,3,4,...,n....,给n个数对<i,j>把数列的i,j两个元素做交换.求交换后数列的逆序对数. 很容易想到离散化+树 ...

  9. Ultra-QuickSort(归并排序+离散化树状数组)

    Ultra-QuickSort Time Limit: 7000MS   Memory Limit: 65536K Total Submissions: 50517   Accepted: 18534 ...

  10. hdu 5869 区间不同GCD个数(树状数组)

    Different GCD Subarray Query Time Limit: 6000/3000 MS (Java/Others)    Memory Limit: 65536/65536 K ( ...

随机推荐

  1. Mac上安装 mySql

    今天在mac系统上安装了 mySql 和大家分享下 安装的过程.. 首先 第一步 需要在oracle的网站下载 mysql 的mac 版本. 下载地址如下: http://www.mysql.com/ ...

  2. Leetcode#172 Fractorial Trailing Zero

    原题地址 n!含有多少个因子10,则结尾有多少个0 10=2*5,而2的个数肯定比5多,所以n!含有多少个因子5,则结尾有多少个0 如何计算n!有多少个因子5呢? 比如n=13,则: n! = 13 ...

  3. shader 里面的分支

    shader 里面的真分支会降低效率 一种方法:构造一个分段函数出来 比如saturate(depth*1.5f)

  4. javascript刷新页面的方法

    Javascript刷新页面的几种方法: 1 history.go(0) 2 location.reload() 3 location=location 4 location.assign(locat ...

  5. 如何撰写SCI论文的讨论部分?——经典结构 – 俗称“倒漏斗型。

  6. UML构建模块(转载)

    UML描述的实时系统,这是非常重要的一个概念模型,然后进行逐渐. UML的概念模型可以通过学习掌握以下三大要素: UML构建模块 规则连接构建模块 UML的公共机制 本章介绍了所有的UML构建块. U ...

  7. H5+ and mui学习记录

    基础 1.H5+ 定义实现了一些调用原生方法的对象 2.其他的原生方法可以通过Native.js调用 webview 3.webview是调用原生界面的H5+对象 4.单个webview只承载单个页面 ...

  8. C#修改注册表设置默认浏览器

    项目中用到VPN技术登录来访问内部网络的应用系统,VPN客户端连接后会自动以默认浏览器来打开站点,由于应用系统使用的前端框架对IE浏览器版本要求较高,而用户大多数的电脑里安装的IE的版本都较低,于是想 ...

  9. js 阻止冒泡 兼容性方法

    function customstopPropagation(e){ var ev = e || window.event; if (ev.stopPropagation) { ev.stopProp ...

  10. poj 1797(最短路变形)

    题目链接:http://poj.org/problem?id=1797 思路:题目意思很简单,n个顶点,m条路,每条路上都有最大载重限制,问1->n最大载重量.其实就是一最短路的变形,定义wei ...