【PAT B-1030】完美数列

【PAT B-1030】完美数列,第1张

【PAT B-1030】完美数列 C++代码

方法一:

//二分查找
#include 
using namespace std;
using gg = long long;
int main() {
    ios::sync_with_stdio(false);
    cin.tie(0);
    gg ni, pi, ans = 0;
    cin >> ni >> pi;
    vector<gg> v(ni);
    for (gg i = 0; i < ni; ++i) {
        cin >> v[i];
    }
    sort(v.begin(), v.end());
    for (gg i = 0; i < ni; ++i) {
        ans = max(ans,
                  upper_bound(v.begin(), v.end(), v[i] * pi) - v.begin() - i);
    }
    cout << ans;
    return 0;
}

方法二:

// two pointers
#include 
using namespace std;
using gg = long long;
int main() {
    ios::sync_with_stdio(false);
    cin.tie(0);
    gg ni, pi, ans = 0;
    cin >> ni >> pi;
    vector<gg> v(ni);
    for (gg i = 0; i < ni; ++i) {
        cin >> v[i];
    }
    sort(v.begin(), v.end());
    for (gg i = 0, j = 0; j < v.size(); ++i) {
        while (j < v.size() and v[j] <= v[i] * pi) {
            ++j;
        }
        ans = max(ans, j - i);
    }
    cout << ans;
    return 0;
}

欢迎分享,转载请注明来源:内存溢出

原文地址:https://54852.com/langs/1294639.html

(0)
打赏 微信扫一扫微信扫一扫 支付宝扫一扫支付宝扫一扫
上一篇 2022-06-10
下一篇2022-06-10

发表评论

登录后才能评论

评论列表(0条)

    保存