HDU-1425 Sort
题目链接:HDU-1425

题目大意:给定数字 排序输出前m大的数
解题思路:首先这么大的数 sort快排应该过不去 其次对输入的数字进行了限定 所以直接用哈希的方式进行判定 倒序输出即可 然后注意输出格式即可 最后一个数字之后不能有空格 否则PE
代码块:
#include<iostream>
#include<cstdio>
#include<cstring>
using namespace std;
int arr[1000001] = {0};
int main(){
int n,m;
while(scanf("%d %d",&n, &m)!=EOF){
int sum = 0;
while(n--){
int p;
scanf("%d",&p);
arr[p+500000]++;
}
for(int i=1000000; i>=0;i--){
if(sum == m) break;
if(arr[i] != 0){
printf("%d",i-500000);
arr[i]--;
i++;
sum++;
if(sum != m)putchar(' ');
}
}
cout<<endl;
memset(arr,0,sizeof(arr));
}
return 0;
}

本文解析了HDU-1425Sort题目,通过使用哈希方式处理限定范围内的数字,实现快速排序并输出前m大的数。代码采用C++实现,详细展示了如何利用哈希表进行倒序输出,同时注意输出格式避免运行时错误。
705

被折叠的 条评论
为什么被折叠?



