标签:class blog code http color com
题目:http://poj.org/problem?id=1328 注意 输出 Case :这里是有个空格的。。和之前序列想法差不多 尽可能 向一边贪心。
| 1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 | #include <cstdio>#include <cstdlib>#include <cstring>#include <algorithm>#include <cmath>#include <stack>#include <queue>#include <vector>#include <map>#include <string>#include <iostream>usingnamespacestd;structNode{    doublel;doubler;}node[11111];doublegao(doubler,doublex ){    returnsqrt(r*r-x*x);}intcmp(constNode &a,constNode &b){    returna.r<b.r;}intmain(){    intn,d;    //freopen("in.txt","r",stdin);    //freopen("out.txt","w",stdout);    doublex,y;intsum=1;    while(scanf("%d%d",&n,&d),n||d){        intjiba=0;        for(inti=0;i<n;i++){            scanf("%lf%lf",&x,&y);            if(y>d||d<0||y<0){                jiba=1;continue;            }            doublelen=gao(d,y);            doublel,r;            l=x-len;r=x+len;            node[i].l=l;node[i].r=r;        }        sort(node,node+n,cmp);        doubleret[11111];        intans=0;        for(inti=0;i<n;i++){            intflag=0;            for(intj=0;j<ans;j++){                if(node[i].l<=ret[j]&&node[i].r>=ret[j]){                    flag=1;break;                }            }            if(!flag){                ret[ans++]=node[i].r;            }        }        printf("Case %d: ",sum++);        if(jiba)            printf("-1\n");        else            printf("%d\n",ans);    }    return0;} | 
标签:class blog code http color com
原文地址:http://www.cnblogs.com/yigexigua/p/3773604.html