比赛 |
20101119 |
评测结果 |
AAAAAAAAAA |
题目名称 |
象棋比赛 |
最终得分 |
100 |
用户昵称 |
郭乾乐 |
运行时间 |
0.000 s |
代码语言 |
C++ |
内存使用 |
0.00 MiB |
提交时间 |
2010-11-19 10:21:13 |
显示代码纯文本
#include<cstdio>
#include<cstdlib>
using namespace std;
int a[100001];
void qst(int l,int r)
{
int mid,i=l,j=r,t;
mid=a[(rand()%(r-l+1))+l];
do
{
while(i<r&&a[i]>mid)
i++;
while(j>l&&a[j]<mid)
j--;
if(i<=j)
{
t=a[i];
a[i]=a[j];
a[j]=t;
i++;
j--;
}
}
while(i<=j);
if(i<r)
qst(i,r);
if(l<j)
qst(l,j);
}
int main()
{
freopen("chess.in","r",stdin);
freopen("chess.out","w",stdout);
int n,i,k;
long long j=0;
scanf("%d%d",&n,&k);
for(i=1;i<=n;i++)
scanf("%d",&a[i]);
qst(1,n);
for(i=1;i<n;i++)
a[i]=a[i]-a[i+1];
qst(1,n-1);
for(i=n-1;i>=n-k;i--)
j+=a[i];
printf("%lld",j);
return 0;
}