cf-754 D Fedor and coupons(优先队列+区间贪心)

https://codeforces.com/problemset/problem/754/D

题意:

给定n组区间,要求选出k组区间保证其交集最大,并输出选出的区间

思路:

区间贪心,优先队列算一下天数即可。

代码:

#include<iostream>
#include<stdio.h>
#include<stdlib.h>
#include<string>
#include<iomanip>
#include<algorithm>
#include<string.h>
#include<queue>
#include<cmath>
#include<stack>

using namespace std;
const int maxn=3e5+10;
const int inf=0x7f7f7f7f;
typedef long long ll;

int n,k;
struct node 
{
    int l,r;
    int idx;
    bool operator<(const node &n)const{
        return l<n.l;
    }
}a[maxn];
priority_queue<int, vector<int>, greater<int>> qq;
int st,ed;

int main()
{
    ios::sync_with_stdio(false);
    cin>>n>>k;
    for(int i=0; i<n; i++)
    {
        cin>>a[i].l>>a[i].r;
        a[i].idx=i+1;
    }
    sort(a,a+n);
    for(int i=0; i<n; i++)
    {
        if(qq.size()==k-1){
            int len=a[i].r-a[i].l+1;
            if(!qq.empty())
             len=min(len,qq.top()-a[i].l+1);
            if(len>ed-st){
                st=a[i].l;
                ed=a[i].l+len;
            }
        }
        qq.push(a[i].r);
        while(qq.size()>=k) qq.pop();
    }
    cout<<ed-st<<endl;
    int res=0;
    for(int i=0; i<n; i++)
    {
        if(res==k)
         break;
        if((a[i].l<=st&&a[i].r+1>=ed)||st==ed){
            cout<<a[i].idx<<" ";
            res++;
        }
    }
    cout<<endl;
    //system("pause");
    return 0;
}

 

posted on 2021-02-01 11:25  mmn  阅读(78)  评论(0编辑  收藏  举报