这道题我们先分析一下 1 ≤ x < y ≤ n , a x ≥ a y 1\leq x < y \leq n,a_x≥a_y 1≤x<y≤n,ax≥ay 这个式子吧~~
首先当 a x ≥ a y a_x≥a_y ax≥ay 的时候且 1 ≤ x < y ≤ n 1\leq x < y \leq n 1≤x<y≤n 成立时,那么第 x x x 号会不满意。也就是说当第 x x x 号同学的分数比第 y y y 号同学的分数高,而且 y y y拿到了礼物而 x x x 的没拿到, x x x就会 不满意。所以可以知道我们发礼物时应该先给分数高的,再给分数较低的。
那么具体思路是什么呢?其实可以用桶存一下每个人的是多少,然后从大到小枚举每个人的分数进行加法直到答案 ≥ k \geq k ≥k
#include <iostream>
#include <algorithm>
using namespace std;
const int maxN = 2 * 1e3 + 5;
int a[maxN], b[125];
int main(){
int n, k, Max = -1, ans = 0;
cin >> n >> k;
for(int i = 1; i <= n; i++){
cin >> a[i];
b[a[i]]++;
Max = max(Max, a[i]);
}
for(int i = Max; i >= 1; i--){
ans += b[i];
if(ans >= k)
{
break;
}
}
cout << ans;
return 0;
}