acgo题库
  • 首页
  • 题库
  • 学习
  • 天梯
  • 备赛

    竞赛

    • CSP-J/S
    • 蓝桥杯

    考级

    • GESP
    • CPA
    • 电子学会考级
  • 竞赛
  • 讨论
  • 团队
  • 商城
登录
注册
题目详情提交记录(0)
  • 题解

    先排个序,用双指针 如果i+j大于限定价格,就只拿j 时间复杂度:O(nlog2n)O(nlog_2n)O(nlog2 n)

    userId_undefined
    cjdst
    尊贵铂金CSP-S一等奖代码纠察员出题人
    38阅读
    0回复
    0点赞
  • 简单

    #include<bits/stdc++.h> using namespace std; const int N = 2e6 + 10; int w,n,a[N]; int main() { cin >> w >> n; for(int i = 1;i <= n;i ++){ cin >> a[i]; } sort(a + 1, a + 1 + n); int sum = 0; int j = n; for(int i = 1;i <= j - 1;i ++){ while(j > i && a[j] + a[i] > w){ j --; sum ++; } if(a[i] + a[j] <= w){ sum ++; j --; } if(i + 1 == j) sum ++; } cout << sum; return 0; }

    userId_undefined
    鳯
    0阅读
    0回复
    0点赞
暂无数据

提交答案之后,这里将显示提交结果~

首页