码迷,mamicode.com
首页 > 其他好文 > 详细

51nod 1278 相离的圆 二分

时间:2018-05-01 17:41:48      阅读:113      评论:0      收藏:0      [点我收藏+]

标签:bsp   turn   相同   out   find   span   style   ++   nod   

将圆化成x轴上的线段,每一个线段有左端点和右端点,按照左端点排序,左端点相同右端点小的在前,然后二分查找与当前线段最接近的线段,得出这是第几个线段,求和。

#include <iostream>
#include <math.h>
#include <algorithm>
#include <stdio.h>
using namespace std;
struct node{
    int l,r;
}a[50005];

bool cmp(node a,node b)
{
    if(a.l==b.l) return a.r<b.r;
    else return a.l<b.l;
 } 
int find(int left,int right,int e)
{
    int ll=left,rr=right;
    int mid;
    while(ll<=rr)
    {
        mid=(ll+rr)/2;
        if(a[mid].l<=e) ll=mid+1;
        else rr=mid-1; 
    }
    return ll;
}

int main()
{
    int n,c,r;
    cin>>n;
    for(int i=0;i<n;i++)
    {
        cin>>c>>r;
        a[i].l=c-r;
        a[i].r=c+r;
    }
    sort(a,a+n,cmp);
    //for(int i=0;i<n;i++) cout<<a[i].l<<" "<<a[i].r<<endl;
    int ans=0;
    for(int i=0;i<n;i++)
    {
        int j=find(i+1,n-1,a[i].r);//cout<<i<<" "<<j<<endl;
        ans+=(n-j);
    }
        
    cout<<ans<<endl;
}

 

51nod 1278 相离的圆 二分

标签:bsp   turn   相同   out   find   span   style   ++   nod   

原文地址:https://www.cnblogs.com/fantastic123/p/8976464.html

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!