5 3 3 -35 92 213 -644
213 92 3
本题由于数据的特殊性,还能用hash思想来做:
#include<iostream>
#include<stdio.h>
int hash[1000010];
int main(int argc, char *argv[])
{
int n,m;
int t;
int cnt;
//freopen("1425.in","r",stdin);
while(scanf("%d %d",&n,&m)==2)
{
memset(hash,0,sizeof(hash));
for(int i=0;i<n;++i)
{
scanf("%d",&t);
hash[t+500000]=1;
}
for(int i=1000010;i>0;i--)
{
if(hash[i])
{
printf("%d",i-500000);
m--;
if(m)
printf(" ");
}
if(m==0) break;
}
printf("\n");
}
return 0;
}
原文地址:http://blog.csdn.net/wdkirchhoff/article/details/41869193