【codevs 1615】数据备份

#include<cstdio>
#include<iostream>
#include<cstring>
#include<algorithm>
#include<cmath>
#include<queue>
#define ll long long
using namespace std;
struct zt
{
    int ct;//区间的序号 
    ll l;//区间内选择的长度 
}; 
bool operator <(zt a,zt b)
{
    return a.l>b.l;
}
priority_queue<zt>q;
const int maxn=1000000+5;
int nxt[maxn],pre[maxn],a[maxn],cnt,tmpre,tmnxt,n,k,tot;
ll len[maxn],ans;
bool del[maxn]; 
int main()
{
    memset(del,0,sizeof(del));
    scanf("%d%d",&n,&k);
    for(int i=1;i<=n;i++) scanf("%d",&a[i]);
    sort(a+1,a+1+n);
    for(int i=1;i<n;i++) 
    {
        len[i]=a[i+1]-a[i];
        pre[i]=i-1;
        nxt[i]=i+1;
        q.push((zt){i,len[i]});
    }
    cnt=n-1;
    len[0]=len[n]=1e12;
    cnt++;
    while(!q.empty())
    {
        zt u=q.top();
        q.pop();
        if(!del[u.ct])//可以选
        {
            tot++;//区间数 
            ans+=u.l;
            if(tot==k)
            {
                printf("%lld",ans);
                return 0;
            }
            tmpre=pre[u.ct],tmnxt=nxt[u.ct];
            u.l=-u.l+len[tmpre]+len[tmnxt];//当前区间内的答案
            nxt[pre[tmpre]]=++cnt;
            nxt[cnt]=nxt[tmnxt];
            pre[nxt[tmnxt]]=cnt;
            pre[cnt]=pre[tmpre];
            len[cnt]=u.l;//当前区间内的答案
            del[tmpre]=del[tmnxt]=del[u.ct]=1;//不可以选 
            u.ct=cnt;
            q.push(u); 
        } 
    }
}
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值