給定乙個正整數數列,和正整數p,設這個數列中的最大值是m,最小值是m,如果m <= m * p,則稱這個數列是完美數列。
現在給定引數p和一些正整數,請你從中選擇盡可能多的數構成乙個完美數列。
輸入第一行給出兩個正整數n和p,其中n(<= 105)是輸入的正整數的個數,p(<= 109)是給定的引數。第二行給出n個正整數,每個數
不超過109。
在一行中輸出最多可以選擇多少個數可以用它們組成乙個完美數列。
10 8
2 3 20 4 5 1 6 7 8 9
8
#include#includeusing namespace std;
int main()
sort(num, num + n);
int i = 0, j = 0, count = 1;
while (i < n && j < n)
j++;
} i++;
} cout
}
PAT乙級 1020完美數列(25)
給定乙個正整數數列,和正整數p,設這個數列中的最大值是m,最小值是m,如果m m p,則稱這個數列是完美數列。現在給定引數p和一些正整數,請你從中選擇盡可能多的數構成乙個完美數列。輸入第一行給出兩個正整數n和p,其中n 105 是輸入的正整數的個數,p 109 是給定的引數。第二行給出n個正整數,每...
乙級 Basic Level 1020 完美數列
給定乙個正整數數列,和正整數p,設這個數列中的最大值是m,最小值是m,如果m m p,則稱這個數列是完美數列。現在給定引數p和一些正整數,請你從中選擇盡可能多的數構成乙個完美數列。輸入第一行給出兩個正整數n和p,其中n 105 是輸入的正整數的個數,p 109 是給定的引數。第二行給出n個正整數,每...
PAT1020 完美數列 有點意思
要點 題目要求乙個數,這個數的範圍是1 n,故可以採用二分查詢這個數。1.假設現在這個數是k,即可以選擇k個數可以用它們組成乙個完美數列。我們做出這個判斷的依據是題目中的條件,故只有這k個數中的最大最小值是要關心的。2.現在將輸入的序列由小到大排列,而1中所用到的這個最大值最大可以是序列的最後乙個元...