Solution
简单贪心和英语阅读题
题意是 为男主的 , 有 次操作能让 个人能力上升1
对每个人只能操作一次, 而相同能力下男主的排位最低
问如何操作能让男主排位最优
我们先让男主能力+1, 次机会减少一次
再让能力比男主低1以上的都加1
为什么呢? 这些人即使加了1也对男主的排位没影响
同理, 大于等于男主能力的都加1
因为本来就大了 加了也不会有影响
最后如果还有 只能让能力比男主小1的人加1
此时相同能力下男主排位会减1
总之, 就是尽可能把操作给对男主排位没影响的人即可
Code
/* autor: Kurisu 2020年4月26日16:37:54 */ #include<bits/stdc++.h> using namespace std; const long long inf = 1e18; const int N = 1e5 + 5; const double eps = 1e-10; const int mod = 1e9 + 7; typedef long long ll; int a[N], vis[N]; int main() { ios::sync_with_stdio(false), cin.tie(nullptr); int t; cin >> t; while(t--) { int n, m; cin >> n >> m; for(int i = 1; i <= n; i++) cin >> a[i]; a[1]++, m--; for(int i = 2; i <= n; i++) { if(a[i] < a[1] - 1 && m) { a[i]++; m--; } } if(m) { for(int i = 2; i <= n; i++) { if(a[i] >= a[1] && m) { a[i]++, m--; } } if(m) { for(int i = 2; i <= n; i++) { if(m && a[i] == a[1] - 1) { a[i]++, m--; } } } } int ans = 0; for(int i = 2; i <= n; i++) { if(a[i] >= a[1]) ans++; } cout << ans + 1 << "\n"; } return 0; }