10020 - Minimal coverage

来源:互联网 发布:网络连接错误807 编辑:程序博客网 时间:2024/05/18 03:10
描述:问题就是刘汝佳书上的的区间选择问题,如果不会的话就看看书吧#include <cstdio>#include <cstdlib>#include <cstring>int n,m;int cmp(const void *p1,const void *p2){    int a=((int *)p1)[0],b=((int *)p1)[1],c=((int *)p2)[0],d=((int *)p2)[1];    if(a<0) a=0;    if(b>m) b=m;    if(c<0) c=0;    if(d>m) d=m;    if( a < c ) return 0;    else if( a == c )    {        if( b < d ) return 0;        else return 1;    }    else return 1;}int num[100010][2],score[100010];int main(){    //freopen("a.txt","r",stdin);    scanf("%d",&n);    while(n--)    {        scanf("%d",&m);        int count=0,sum=0,flag=0,v=0;        while(scanf("%d %d",&num[count][0],&num[count][1])!=EOF)            if(!num[count][0]&&!num[count][1]) break;            else count++;        qsort(num,count,sizeof(num[0]),cmp);        for(int i=0; i<count; i++)        {            if(num[i][0]<=flag&&num[i][1]>flag)            {                if(v<num[i][1])                {                    v=num[i][1];                    score[sum]=i;                    if(v>=m)                    {                        sum++;                        break;                    }                }            }            else            {                if(num[i][0]>flag&&num[i][0]<=v&&num[i][1]>v)                {                    flag=v;                    score[++sum]=i;                    v=num[i][1];                    if(v>=m)                    {                        sum++;                        break;                    }                }            }        }        if(v<m) sum=0;        printf("%d\n",sum);        for(int i=0; i<sum; i++)            printf("%d %d\n",num[score[i]][0],num[score[i]][1]);        if(n) printf("\n");    }    return 0;}

原创粉丝点击