C++学习之路 | PTA乙级—— 1030 完美数列 (25 分)(精简)
生活随笔
收集整理的這篇文章主要介紹了
C++学习之路 | PTA乙级—— 1030 完美数列 (25 分)(精简)
小編覺得挺不錯的,現在分享給大家,幫大家做個參考.
1030 完美數列 (25 分)
給定一個正整數數列,和正整數 p,設這個數列中的最大值是 M,最小值是 m,如果 M≤mp,則稱這個數列是完美數列。
現在給定參數 p 和一些正整數,請你從中選擇盡可能多的數構成一個完美數列。
輸入格式:
輸入第一行給出兩個正整數 N 和 p,其中 N(≤10
?5
?? )是輸入的正整數的個數,p(≤10
?9
?? )是給定的參數。第二行給出 N 個正整數,每個數不超過 10
?9
?? 。
輸出格式:
在一行中輸出最多可以選擇多少個數可以用它們組成一個完美數列。
輸入樣例:
10 8
2 3 20 4 5 1 6 7 8 9
輸出樣例:
8
#include<iostream> #include<vector> #include<algorithm> using namespace std; int main() {int N, p, x;vector<int>v;cin >> N >> p;for (int i = 0; i < N; i++){cin >> x;v.push_back(x);}sort(v.begin(), v.end());int i, max_1 = 0,j=0;for (i = 0; i < N; i++){long min = v[i];while (j < N && min * p >= v[j]) {j++;}int count = j - i;max_1 = max(count, max_1);}cout << max_1;}總結
以上是生活随笔為你收集整理的C++学习之路 | PTA乙级—— 1030 完美数列 (25 分)(精简)的全部內容,希望文章能夠幫你解決所遇到的問題。
- 上一篇: jmeter里的连接数_Jmeter之连
- 下一篇: mysql 内存 256m_解决mySQ