比赛 ZLXSCDay1 评测结果 AAWWWWWWWW
题目名称 PERICA 最终得分 20
用户昵称 Slowy 运行时间 0.182 s
代码语言 C++ 内存使用 0.70 MiB
提交时间 2016-03-18 21:10:03
显示代码纯文本
//perica.cpp
#include <iostream>
#include <cstdio>
#include <algorithm>
using namespace std;

const int maxn=100100;
const int p=1000000007;
int n,k,a[maxn],u,v;
long long ans,t;
void ni(int x,int y){
	int u1,v1;
	if(y==0){
		u=1; v=0;
	}
	else{
		ni(y,x%y);
		u1=v; v1=u-x/y*v;
		u=u1; v=v1;
	}
}
int main(){
	freopen("perica.in","r",stdin);
	freopen("perica.out","w",stdout);
	scanf("%d%d",&n,&k);
	for(int i=0;i<n;++i)scanf("%d",&a[i]);
	sort(a,a+n); ans=a[k-1]; t=1;
	for(int i=k;i<n;++i){
		ni(i-k+1,p);
		if(u<0)u+=p;
		t=t*i*u;
		ans=(ans+t*a[i])%p;
	}
	cout<<ans;
	return 0;
}