[PAT乙级]1030 完美数列
生活随笔
收集整理的這篇文章主要介紹了
[PAT乙级]1030 完美数列
小編覺得挺不錯的,現在分享給大家,幫大家做個參考.
給定一個正整數數列,和正整數 p,設這個數列中的最大值是 M,最小值是 m,如果 M≤mp,則稱這個數列是完美數列。
現在給定參數 p 和一些正整數,請你從中選擇盡可能多的數構成一個完美數列。
輸入格式:
輸入第一行給出兩個正整數 N 和 p,其中 N(≤10?5??)是輸入的正整數的個數,p(≤10?9??)是給定的參數。第二行給出 N 個正整數,每個數不超過 10?9??。
輸出格式:
在一行中輸出最多可以選擇多少個數可以用它們組成一個完美數列。
輸入樣例:
輸出樣例:
8代碼如下:
#include <iostream> #include <algorithm> using namespace std; const int N = 100010; long long int a[N]; int main() {int n, p;cin >> n >> p;for (int i = 0; i < n; i++)cin >> a[i];sort(a, a + n);int ans = 0;for (int i = 0;i<n;i++)for (int j = i + ans; j < n && a[j] <= a[i] * p; j++){int tmp = j - i + 1;if (tmp > ans) ans = tmp;}cout << ans << endl;return 0;}總結
以上是生活随笔為你收集整理的[PAT乙级]1030 完美数列的全部內容,希望文章能夠幫你解決所遇到的問題。
- 上一篇: 消息称 OpenAI 新董事同意对 Al
- 下一篇: [PAT乙级]1029 旧键盘