[PAT乙级]1030 完美数列
生活随笔
收集整理的這篇文章主要介紹了
[PAT乙级]1030 完美数列
小編覺得挺不錯的,現(xiàn)在分享給大家,幫大家做個參考.
給定一個正整數(shù)數(shù)列,和正整數(shù) p,設(shè)這個數(shù)列中的最大值是 M,最小值是 m,如果 M≤mp,則稱這個數(shù)列是完美數(shù)列。
現(xiàn)在給定參數(shù) p 和一些正整數(shù),請你從中選擇盡可能多的數(shù)構(gòu)成一個完美數(shù)列。
輸入格式:
輸入第一行給出兩個正整數(shù) N 和 p,其中 N(≤10?5??)是輸入的正整數(shù)的個數(shù),p(≤10?9??)是給定的參數(shù)。第二行給出 N 個正整數(shù),每個數(shù)不超過 10?9??。
輸出格式:
在一行中輸出最多可以選擇多少個數(shù)可以用它們組成一個完美數(shù)列。
輸入樣例:
輸出樣例:
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;}總結(jié)
以上是生活随笔為你收集整理的[PAT乙级]1030 完美数列的全部內(nèi)容,希望文章能夠幫你解決所遇到的問題。
- 上一篇: 消息称 OpenAI 新董事同意对 Al
- 下一篇: [PAT乙级]1029 旧键盘