码迷,mamicode.com
首页 > 编程语言 > 详细

想离的圆(排序+二分查找)

时间:2017-12-17 18:14:40      阅读:199      评论:0      收藏:0      [点我收藏+]

标签:tde   ring   new   turn   todo   detail   next   sort   第一个   

题目:http://www.51nod.com/onlineJudge/submitDetail.html#!judgeId=427658

先将圆的在X轴上左起点按升序排序,再用二分查找第一个起点比待查找圆的终点大的圆(即相离)

import java.util.Arrays;
import java.util.Comparator;
import java.util.Scanner;

class circle
    {
        int x,r,sta,end;
        circle(int x, int r)
        {
            this.x=x;
            this.r=r;
            this.sta=x-r;
            this.end=x+r;
        }
    }
public class N1278 {
    
    public static void main(String[] args) {
        // TODO Auto-generated method stub
        Scanner cin=new Scanner(System.in);
        
        int n=cin.nextInt();
        circle c[]=new circle[n];
        for(int i=0;i<n;i++)
            c[i]=new circle(cin.nextInt(),cin.nextInt());
        Arrays.sort(c,new Comparator<circle>()
        {
            public int compare(circle c1,circle c2)
            {
                if(c1.sta>=c2.sta)
                    return 1;
                else
                    return -1;
            }
        });
        int sum=0;

        for(int i=0;i<n-1;i++)
        {
            int p=search(i,c,n);
            if(p!=-1)
                sum+=n-p;
        }
        System.out.print(sum);
    }
    public static int search(int pos,circle c[],int len)
    {
        int key=c[pos].end,begin=pos+1,last=len-1;
        while(begin<last)
        {
            int mid=(begin+last)/2;
            
            if(c[mid].sta>key)
                last=mid;
            else
                begin=mid+1;
        }
        if(c[begin].sta>key)
            return begin;
        else
            return -1;
    }

}

 

想离的圆(排序+二分查找)

标签:tde   ring   new   turn   todo   detail   next   sort   第一个   

原文地址:http://www.cnblogs.com/NDKY9/p/8052590.html

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