题解
2024-04-28 13:30:12
发布于:广东
14阅读
0回复
0点赞
先排个序,用双指针
如果i+j大于限定价格,就只拿j
#include <iostream>
#include <cstdio>
#include <algorithm>
using namespace std;
int a[100005];
int main(){
int n, m;
cin >> m >> n;
for(int i = 1; i <= n; i++){
cin >> a[i];
}sort(a + 1, a + n + 1);
int i = 1, j = n, ct = 0;
while(i <= j){
if(a[i] + a[j] <= m) i++, j--;//不超过限定价格一起拿
else j--;//超过限定价格只拿j
ct++;
}cout << ct;
return 0;
}
时间复杂度:
全部评论 1
我丢已经有人这么做了
2024-04-30 来自 广东
0
有帮助,赞一个